NOW - New and Old Worlds - Database of fossil mammals
Rebuild of a fossil database application, old version at https://nowdatabase.luomus.fi/
The new version is not deployed yet.
Basic commands π»
npm run setup
- Installs all node modules, and generates prisma client
npm run dev
- Uses
docker-compose.dev.yml
- Run in development mode: with hot reload
- To create test users visit
http://localhost:4000/test/create-test-users
- Uses
Testing:
npm run check
- Runs
tsc
andeslint
for frontend and backend: Use this to check for errors before committing.
- Runs
npm run test:api
- Runs the api-tests in a docker container
- Requires database to be running. Can be achieved by
npm run start:anon -- db-anon
or justnpm run start:anon:api
. - Uses
test_data
- Uses
.test.env
npm run test:api:build
builds the container used to run the tests.npm run test:api:run
runs the previously built container.
npm run test:e2e
- Runs e2e-tests inside a docker container.
- Requires
frontend
,backend
anddatabase
to be running. Can be achieved by runningnpm run start:anon
. - Uses
test_data
npm run test:e2e:local
- Runs cypress-tests locally (not in docker) in headless mode.
- Requires
npm run start:anon
to be running first.
npm run test:api:local
- Runs backend api tests locally (not in docker).
- Requires
db-anon
to be running first. (Note: backend doesn't need to be running.) - Requires
.test.env
npm run cypress
- Opens cypress GUI. You can run tests and see what they do.
Windows testing:
- Both
e2e
andapi-tests
have a Windows specific command.e2e
isnpm run test:e2e:windows
api-tests
isnpm run test:api:windows
- For
api-tests
: inside.test.env
, you need to change all instances oflocalhost
tohost.docker.internal
.- These include
MARIADB_HOST
,DATABASE_URL
andLOG_DATABASE_URL
.
- These include
- Note: these are not tested yet.
Test env-file:
.test.env
api-tests
requires.test.env
to set the correct environment variables.- This is created by copying
.anon.env
and changing all instances ofnowdb-db-anon
tolocalhost
.- These include
MARIADB_HOST
,DATABASE_URL
andLOG_DATABASE_URL
.
- These include
Coverage:
- Coverage opening
- Coverage can be opened by opening the
coverage/lcov-report/index.html
with your browser of choice.
- Coverage can be opened by opening the
coverage:sed
- Fixes issues with
.nyc_output
paths. Replaces the paths inside Docker to$PWD
(current directory).
- Fixes issues with
coverage
- First fixes paths with
coverage:sed
and then recreatescoverage/lcov-report
to match the new path.
- First fixes paths with
coverage:report
- Alias to
npm run coverage
. Used by cypress e2e tests so thatcoverage:sed
gets executed automatically.
- Alias to
Run with the same image that is used in production:
npm start
- Uses
docker-compose.yml
- This builds the code and runs it. Mostly you'll want to use this after major technical changes to check the code works also in production mode, before deploying. And then you'll likely want to do:
npm start -- --build
to force rebuild of containers.
- Uses
Docker:
npm run dev:down
- Stops and removes the dev container and it's volumes.
-- --build
- Useful flag to force docker to rebuild the containers. Example usage for dev:
npm run dev -- --build
- Useful flag to force docker to rebuild the containers. Example usage for dev:
Further documentation
π Initialize app & restore db How to get the app up & running, and initialize database from sql-dumps
π§ Technical explanations Explanations of how things work, and guides for some more rare tasks like updating database-schema
π Contributing & integration flow Where to commit? Where are tests run? How is the code deployed?
π Frontend Explanation of the frontend logic and how to add views
π Validators The readme explains how validators are written
π Class diagram See the relations of relevant tables. Notice that it omits some unimportant tables and does not show most columns.
π Map features Maps' functionality and development notes