Skip to content
This repository has been archived by the owner on Jan 10, 2024. It is now read-only.

Latest commit

 

History

History
228 lines (167 loc) · 8.9 KB

README.md

File metadata and controls

228 lines (167 loc) · 8.9 KB

DV Stip Workspace

Welcome to DV Stip Workspace!

Glossary

The following abbreviations are being used in this documentation:

  • GS: Gesuchsteller, also sometimes known as Antragssteller.
  • SB: Sachbearbeiter

Getting Started

Install global nx CLI with npm i -g nx as it will make running of some commands easier. Install the dependencies with npm ci (append --legacy-peer-deps or --force if necessary)

The --legacy-peer-deps flag might need to used in case the dependencies available at the time of last workspace update did not fulfil their peerDependencies ranges perfectly. This might change again in the future as newer versions of the libraries are released and the --legacy-peer-deps flag might not be needed anymore.

In order to install the dependency @kibon/stip-contract a DvBern internal access is needed. Follow this tutorial to setup the access to the private npm registry.
For external users, please uninstall the @kibon/stip-contract in order to use this repository. It is only required to update the models and interfaces.

There are two different Apps that can be built, served, tested, etc: gesuch-app and sachbearbeitung-app. npm run start for example starts the GS and SB App.

Task Gesuch-App Sachbearbeitung-App All
Serve npm run start:gs npm run start:sb npm run start
Build npm run build:gs npm run build:sb npm run build
Lint npm run lint:gs npm run lint:sb npm run lint
Test npm run test:gs npm run test:sb npm run test
e2e npm run e2e:gs npm run e2e:sb npm run e2e
Validate - - npm run validate

Authorization

During local development the dev Auth instance is being used. The Authorization is being handled by a dedicated Keycloak instance.

To obtain a test user it is possible to log in the administration panel on https://auth.stip.dev.apps.test.kibon.ch/admin/master/console/#/bern/users using the credentials found at LastPass, search for stip and use the Keycload Admin (DEV) credentials. After that follow these steps to create a new user or modify existing ones:

  1. Add User
  2. Set Username, Email (optional), First name and Last name
  3. Create
  4. Select newly created user
  5. Go to Credentials tab -> Set password -> fill new password -> Disable Temporary
  6. Set Roles for the user Role mapping -> Assign role -> Admin or GS/SB related roles.

TLDR local development:

  1. npm ci (check that @kibon/stip-contract is installable, as mentioned above)
  2. Ensure that the API and everything else is running:
  3. Ensure the Authorization is configured
  4. npm run start or npm run start:gs / npm run start:sb

Architecture

Stip uses a very strict but also robust software architecture, i.e. the arrangement of the files and their affiliations are predefined and compliance with this structure is also verified with validators.

Both apps have a big common part, the Gesuch Formular views. These Features and Pages are shared between both apps using a sub router outlet approach:

  • GesuchApp (App) -> <router-outlet>

    • Cockpit (Feature) / <dv-gesuch-app-pattern-main-layout>
    • Gesuch Form (Feature) -> <dv-gesuch-app-pattern-gesuch-step-layout>.<router-outlet>
      • shared/Gesuch Form Person (Feature)
      • shared/Gesuch Form Ausbildung (Feature)
      • shared/Gesuch Form Eltern (Feature)
      • ...
  • SachbearbeitungApp (App) -> <router-outlet>

    • Cockpit (Feature) / <dv-sachbearbeitung-app-pattern-overview-layout>
    • Gesuch Form (Feature) -> <dv-sachbearbeitung-app-pattern-gesuch-step-layout>.<router-outlet>
      • shared/Gesuch Form Person (Feature)
      • shared/Gesuch Form Ausbildung (Feature)
      • shared/Gesuch Form Eltern (Feature)
      • ...

More details about this structure can be found here.

Adding Code (Features, Data-Access, etc)

To ensure that the architecture is being upheld correctly, a multitude of generators and other costumization tools can be used.

Use the tools that are mentioned in the Workspace documentation.

Linting

npm run lint

A general overview on how the linting works in this project can be found here.

Testing

Unit testing

npm run test

In general, we strive to write components with little or even NO logic at all which means they don't really have to be tested. This is great because components are the most complicated part of Angular application to test and those tests execute run the slowest.

Most logic is then extracted into data-access or util type libraries which are headless and hence much easier to test.

The main product critical flows should be covered by the e2e tests which provide the best tradeoff between effective / useful coverage and effort required to write them.

E2E

// Headless
`npm run e2e`

// Visual
`npm run e2e:gs:open`
`npm run e2e:sb:open`

Preparation:

  1. Copy .env.template to .env
  2. Fill the values DEV Keycloak Credentials from LastPass (LastPass -> Stip E2E (DEV))

You can run e2e tests in headless mode for all (npm run e2e) or for a specific app (npm run e2e:<app-name>, these have to be added to the package.json file scripts when new app is added to the workspace).

Besides that it is also possible to serve desired app in the dev mode (eg npm run serve:gs) and then start e2e tests in GUI mode with npm run e2e:gs:open which will start Cypress GUI. (again, these scripts have to be added to the package.json file scripts when new app is added to the workspace).

When writing E2E tests, always make sure to use data-testid="some-id" attributes instead of component selectors, classes or other attributes. This way we can make sure that tests are not brittle and will not break when we change the component structure or styling.

Component tests

Generate a new test for a library:

nx g @nx/angular:cypress-component-configuration --project=your-project --build-target=your-build-configuration:build

where your-project is the project name of your library and your-build-configuration is the chosen build target build target, e.g. "gesuch-app:build" This generates the cypress files with the necessary configurations. If you don't need the fixtures folder, you can remove it manually.

You then have to make the following adaptions to enable code coverage:

// cypress/support/component.ts
// add line
import '@cypress/code-coverage/support';

In the same directory as the cypress.config.ts file, create the following file, named coverage.webpack.ts:

export const setupCoverageWebpack = (paths: string[]) => ({
  module: {
    rules: [
      {
        test: /\.(js|ts)$/,
        loader: '@jsdevtools/coverage-istanbul-loader',
        options: { esModules: true },
        enforce: 'post',
        include: paths,
        exclude: [/\.(cy|spec)\.ts$/, /node_modules/],
      },
    ],
  },
});

Then, replace the content in cypress.config.ts with:

import { nxComponentTestingPreset } from '@nx/angular/plugins/component-testing';
import task from '@cypress/code-coverage/task';
import { defineConfig } from 'cypress';
import * as path from 'path';

import { setupCoverageWebpack } from './coverage.webpack';

const nxPreset = nxComponentTestingPreset(__filename);

export default defineConfig({
  component: {
    ...nxPreset,
    devServer: {
      ...nxPreset.devServer,
      webpackConfig: setupCoverageWebpack([path.join(__dirname, 'src')]),
    },
    setupNodeEvents(on, config) {
      task(on, config);
      return config;
    },
  },
  scrollBehavior: 'nearest',
});

Troubleshooting

NX monorepo is a great piece of technology, but it is not perfect. Even though caching leads to great performance it can also lead to inconsistent state, especially when removing, moving or renaming projects and files. If you run into any issues try to run nx reset (or `npm run reset) and then try to run original command again. If the problem still persists then it's most likely a real problem which than has to be solved.