lundi 1 octobre 2018

How to test React-Leaflet map component

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:

enter image description here

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="&amp;copy <a href=&quot;http://osm.org/copyright&quot;>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