phatnguyenuit / meta-weather

Meta Weather Forecast
https://meta-weather-seven.vercel.app
MIT License
3 stars 1 forks source link
cypress end-to-end-testing forecast javascript jest material-ui react-hooks reactjs typescript vercel weather

Meta Weather

CI/CD codecov License

This project was bootstrapped with Create React App.

Preview

Table of Contents

Go to top ⏫

Introduction

This project inspired on building a weather forecast website. Using Meta Weather Public API to get weather forecast data.

*Warning: Cause of CORS issue on Meta Weather Public API, so I decided to build a simple proxy server to serve API data for my webapp.*

Go to top ⏫

Preview

Deployed ✅ on Vercel: ➡ Click here to access!

Features

Go to top ⏫

Flow diagram

Getting current weather based on user location

Flow diagram for getting current weather based on user location

Go to top ⏫

Prerequisites

Go to top ⏫

Installation

Go to top ⏫

Code coverage

Usage

$ yarn test --coverage --watchAll

Current code coverage is 97%

Code-coverage-97-percent

Go to top ⏫

End to end testing with Cypress

Prepare environment

$ cp cypress.env.json.example cypress.env.json
{
  "host": "
    web host to test (can be your deployed url)
    localhost can only use in cypress open not cypress run.
    Use IP address of your local instead 
    Example: 
     - http://xxx.yyy.zz.tt:port
     - https://www.your-website.com
  "
}

GUI mode

$ yarn cy:open

Main UI to interact

Cypress-GUI-mode

Chrome browser test runner

Cypress-Chrome

Headless mode

$ yarn cy:open

Cypress-headless-mode

Go to top ⏫

Technologies

Go to top ⏫

Responsive UI

Go to top ⏫

Dashboard

On large screen

Large screen

Go to top ⏫

On small screen

Small screen

Go to top ⏫

On mobile screen

Mobile screen

Go to top ⏫

Search city page

On large screen

Large screen

Go to top ⏫

On small screen

Small screen

Go to top ⏫

On mobile screen

Mobile screen

Go to top ⏫

City weather page

On large screen

Large screen

Go to top ⏫

On small screen

Small screen

Go to top ⏫

On mobile screen

Mobile screen

Go to top ⏫

Learn More

Go to top ⏫

Changelog

See CHANGELOG.md

License

MIT © Phát Nguyễn (Fast)