I have little knowlegde when it comes to test React Components, so I'm sorry in advance for this question.
I developed a map component that is working, but I would like to perform some tests, just to make sure everything is running smoothly.
I tried the most simple example:
it('renders without crashing', () => {
const div = document.createElement('div');
ReactDOM.render(<BikeMap />, div);
ReactDOM.unmountComponentAtNode(div);
});
But I get an error:
What other tests should I perform for this map component?
Here's the map component:
import React, { Component } from 'react';
import L from 'leaflet';
import { Map, TileLayer, Marker, Popup } from 'react-leaflet';
import MarkerClusterGroup from 'react-leaflet-markercluster';
import 'react-leaflet-markercluster/dist/styles.min.css';
// code for map marker icon
var myIcon = L.icon({
iconUrl: '',
iconSize: [25, 41],
iconAnchor: [12.5, 41],
popupAnchor: [0, -41]
});
export default class BikeMap extends Component {
constructor(props) {
super(props);
this.state = {
location: {
lat: 51.505,
lng: -0.09,
},
bikeData: [],
isLoading: true,
haveUsersLocation: false,
zoom: 3
}
}
//code for loading
componentWillMount() {
setTimeout(() => this.setState({
isLoading: false
}), 2000);
}
componentDidMount() {
//code to get the bike information
fetch('https://api.citybik.es/v2/networks')
.then(res => {
if (!res.ok) {
throw new Error(res.status);
}
return res.json();
})
.then(response => {
const networkData = response.networks;
this.setState({
bikeData: networkData
});
})
.catch(error => {
console.log(error);
});
//code to get the user's location(if so desires)
navigator.geolocation.getCurrentPosition((position) => {
this.setState({
location: {
lat: position.coords.latitude,
lng: position.coords.longitude
},
haveUsersLocation: true,
zoom: 6
});
}, () => {
console.log('Uops! The user didnt give its location!');
fetch('https://ipapi.co/json')
.then(res => {
if (!res.ok) {
throw new Error(res.status);
}
return res.json();
})
.then(location => {
this.setState({
location: {
lat: location.latitude,
lng: location.longitude
},
haveUsersLocation: true,
zoom: 13
});
})
.catch(error => {
console.log(error);
})
});
}
render() {
const { isLoading } = this.state;
const position = [this.state.location.lat, this.state.location.lng]
const bikeData = this.state.bikeData;
if (isLoading) {
return <div className="spinner"></div>
}
return (
<Map className="map markercluster-map" center={position} zoom={this.state.zoom}>
<TileLayer
attribution="&copy <a href="http://osm.org/copyright">OpenStreetMap</a> contributors"
url="https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png"
/>
<MarkerClusterGroup>
{
bikeData && bikeData.map((data, index) => {
const company = data.company;
if (company) {
const companyList = company.map((station, index) => {
return (
<div key={index}>{station}</div>
)
})
return (
<Marker
icon={myIcon}
key={data.id}
position={[data.location.latitude, data.location.longitude]}>
<Popup>
<b>City:</b> {data.location.city} <br />
<b>Country:</b> {data.location.country} <br />
<b>Name of Network:</b> {data.name} <br />
<b>Number of Stations:</b> {data.company.length} <br />
<b>Name of Stations:</b> {companyList}
</Popup>
</Marker>
)
}
return <div key={index}>No Data</div>
})
}
</MarkerClusterGroup>
</Map>
)
}
}
Thank you!
Aucun commentaire:
Enregistrer un commentaire