Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/codecov/gazebo
React SPA
https://github.com/codecov/gazebo
codecov fair-source react test-coverage typescript vite
Last synced: 6 days ago
JSON representation
React SPA
- Host: GitHub
- URL: https://github.com/codecov/gazebo
- Owner: codecov
- License: other
- Created: 2020-11-05T15:12:50.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2025-01-16T02:16:25.000Z (6 days ago)
- Last Synced: 2025-01-16T03:25:34.342Z (6 days ago)
- Topics: codecov, fair-source, react, test-coverage, typescript, vite
- Language: TypeScript
- Homepage: https://app.codecov.io/login
- Size: 67.3 MB
- Stars: 52
- Watchers: 4
- Forks: 23
- Open Issues: 35
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
# Gazebo
[![codecov](https://codecov.io/gh/codecov/gazebo/branch/main/graph/badge.svg?token=UAP786D58M)](https://codecov.io/gh/codecov/gazebo)
> We believe that everyone should have access to quality software (like Sentry), that’s why we have always offered Codecov for free to open source maintainers.
>
> By making our code public, we’re not only joining the community that’s supported us from the start — but also want to make sure that every developer can contribute to and build on the Codecov experience.Gazebo is the Front-end SPA of Codecov. It's a greenfield project we kicked off in November 2020 with the ambition of rewriting all the legacy pages from [codecov.io](https://github.com/codecov/codecov.io) and [codecov-client](https://github.com/codecov/codecov-client) in a single repository with a more modern approach.
This project was bootstrapped with [Vite](https://vitejs.dev/).
## Prerequisites
We recommend using the same Node version as defined in the `package.json`, you can also refer to the `.nvmrc` in the root folder.
In order to use the Makefile to build a Docker image, you'll need to set an environment variable for `CODECOV_GAZEBO_IMAGE`. Set it to a string that will be used as a Docker image name to build to.
## Run the project
To run the project in development mode
```bash
> yarn
> yarn start
```Note: The first run of `yarn start` may take 5-10 minutes to finish building.
The page will reload when you make edits. There is a local proxy to the staging API so you can develop against it. You can overwrite it by creating a `.env.development.local` file with it with the following:
```text
PROXY_TO=http://localhost:5100
```## Run tests
You can run the tests with
```bash
> yarn test
```This script is using Vitest, so any valid Vitest options can be added to the command.
We are using the [Testing Library](https://testing-library.com/docs/react-testing-library/intro) to test the React components.
## Linting
```bash
> yarn lint
```will lint the whole project.
## Build the application for production
```bash
> yarn build
```will build the application in the `build` folder.
## Config
The config are centralized in one place in the file `config.js`. The file merges multiple configuration in one object:
- hardcoded configuration in that file
- the configuration from [process.env](#processenv) which is set on build-time
- the configuration from `window.configEnv` which can be set on start-time### process.env
Gazebo supports [env files](https://vite.dev/guide/env-and-mode.html#env-variables-and-modes) by default which become environment variables at build-time.
To override environment variables when working locally create a `.env.development.local` file, this file is ignored by git.
You must prepend env variables with `REACT_APP`.
```text
# .env.development.local
PROXY_TO=https://stage-api.codecov.dev
REACT_APP_MY_CUSTOM_VAR=foobar
REACT_APP_BASE_URL=http://localhost
``````js
// src/somefile.jsimport config from 'config'
console.log(config.MY_CUSTOM_VAR) // foobar
```Currently there's three env variables you may want to change when working locally:
- PROXY_TO (Change where Gazebo API services are pointing to)
- REACT_APP_MSW_BROWSER (boolean to enable mocking api requests in browser, see [How to mock HTTP responses in the browser](#How-to-mock-HTTP-responses-in-the-browser))
- REACT_APP_BASE_URL (This is the base url where the legacy web container resides, needed for login/signout links)## How to mock HTTP responses in the browser:
Sometimes when working locally it helps to control API responses. For edge cases, for investigating support or on call incidents.
If you need to mock a response add `REACT_APP_MSW_BROWSER=true` to `.env.development.local` to enable browser mocks.
Mocks are located in `src/mocks/handlers`Example:
```js
import { http, HttpResponse } from 'msw'export const handlers = [
http.get('internal/user', (req, res, ctx) => {
return HttpResponse.json({ data: { mock: 'data' } })
}),
]
```Read more at the [official documentation.](https://mswjs.io/docs/getting-started/mocks/rest-api)
## Contributing
This repository, like all of Codecov's repositories, strives to follow our general [Contributing guidelines](https://github.com/codecov/contributing).
If you're considering making a contribution to this repository, we encourage review of our Contributing guidelines first.