Skip to content

Latest commit

 

History

History
115 lines (77 loc) · 3.63 KB

README.md

File metadata and controls

115 lines (77 loc) · 3.63 KB

E2E Tests

Frontend

Setup

  1. Install dependencies with pnpm install
  2. Execute a build with pnpm build
  3. Start development environment and watchers with pnpm start
  4. Run tests with pnpm test

Applications

This repo holds multiple applications, read more about getting started with each application in their respective README.

Repository structure

This is the invisioned structure for the future.

.
├── apps ─ End products
│   ├── rehabstod
│   └── webcert
└── packages ─ Shared between applications and libraries
    ├── eslint-config-custom ─ Linting configuration
    ├── eslint-config-react ─ Linting configuration for react applications
    └── ...

Shared libraries

The /packages folder contain documented libraries that is utilized between applications/libraries.

Shared libraries should generally:

  1. Output ECMAScript modules that applications and other libraries can consume.
  2. Contain a README.md, outlining it's functionality.
  3. Be added to root tsconfig.json's paths, for symbol navigation.

Exceptions can be made, for example eslint packages only outputs commonjs since eslint still uses that. And combine-coverage only holds a binary that the root application uses to combine application test-reports.

Configure Editors

IntelliJ

  • Install Prettier plugin.
  • Configure to use prettier when formatting in IntelliJ (requires IntelliJ 2020.2). See Settings -> Language & Frameworks -> Javascript -> Prettier
  • Make sure ESLint is enabled and enable "Run eslint --fix on save".

VS Code

  • Install plugin ESLint

  • Install plugin vscode-styled-components

  • Install plugin Prettier - Code formatter

  • Enable auto format on save

    • Press ctrl + shift + p, type settings and open Preferences: Open Settings (JSON)

    • Add the following properties

      {
        "editor.defaultFormatter": "esbenp.prettier-vscode",
        "editor.formatOnSave": true
      }
    • Add the following properties (optional)

      "editor.codeActionsOnSave": {
        "source.organizeImports": true,
        "source.fixAll": true
      }

Plugin recommendations can be found by opening the extension panel ctrl + x and type @recommended

Unit tests

vitest is used for executing tests.

To run tests in all packages pnpm test

To run tests in all packages with ui pnpm test:ui

To run any perticular test pnpm test /{apps, packages}/<name of application/something.test.ts

To run tests in a perticular package pnpm --filter <package_name> test

Read more about filtering

Writing tests

Build pipelines

Read about build pipelines using openshift.

Resources