mirror of
https://github.com/solidtime-io/solidtime.git
synced 2026-06-15 13:32:43 +01:00
79 lines
2.1 KiB
Markdown
79 lines
2.1 KiB
Markdown
# Time-tracking project
|
|
|
|
## Setup the Project
|
|
|
|
System Requirements:
|
|
* Docker
|
|
* PHP 8.3
|
|
* Composer
|
|
|
|
```bash
|
|
composer install
|
|
|
|
cp .env.example .env
|
|
|
|
./vendor/bin/sail up -d
|
|
|
|
./vendor/bin/sail artisan key:generate
|
|
|
|
./vendor/bin/sail artisan migrate:fresh --seed
|
|
|
|
./vendor/bin/sail php artisan passport:install
|
|
|
|
./vendor/bin/sail npm install
|
|
|
|
./vendor/bin/sail npm run build
|
|
|
|
```
|
|
|
|
Make sure to set the APP_PORT and VITE_PORT inside your `.env` file to a port that is not already used by your system.
|
|
|
|
## Setup with Reverse Proxy
|
|
|
|
Additional System Requirements:
|
|
* Traefik 2 Reverse-Proxy (https://github.com/korridor/reverse-proxy-docker-traefik)
|
|
|
|
Add the following entry to your `/etc/hosts`
|
|
|
|
```
|
|
127.0.0.1 solidtime.test
|
|
127.0.0.1 playwright.solidtime.test
|
|
127.0.0.1 vite.solidtime.test
|
|
127.0.0.1 mail.solidtime.test
|
|
```
|
|
|
|
## Running E2E Tests
|
|
|
|
`./vendor/bin/sail up -d ` will automatically start a Playwright UI server that you can access at `https://playwright.solidtime.test`.
|
|
Make sure that you use HTTPS otherwise the resources will not be loaded correctly.
|
|
|
|
## Recording E2E Tests
|
|
|
|
To record E2E tests, you need to install and execute playwright locally (outside the Docker container) using:
|
|
|
|
```bash
|
|
npx playwright install
|
|
npx playwright codegen solidtime.test
|
|
```
|
|
|
|
## E2E Troubleshooting
|
|
|
|
If E2E tests are not working at all, make sure you do not have the Vite server running and just run `npm run build` to update the version.
|
|
If the E2E tests are not working consistently and fail with a timeout during the authentication, you might want to delete the `test-results/.auth` directory to force new test accounts to be created.
|
|
|
|
## Generate ZOD Client
|
|
|
|
The Zodius HTTP client is generated using the following command:
|
|
|
|
```bash
|
|
|
|
npm run zod:generate
|
|
```
|
|
|
|
## Contributing
|
|
|
|
This project is in a very early stage. The structure and APIs are still subject to change and not stable.
|
|
Therefore we do not currently accept any contributions, unless you are a member of the team.
|
|
|
|
As soon as we feel comfortable enough that the application structure is stable enough, we will open up the project for contributions.
|