Skip to content

Latest commit

 

History

History
175 lines (126 loc) · 6.34 KB

README.md

File metadata and controls

175 lines (126 loc) · 6.34 KB

The DfSSETA Apply for Landing Application

Overview

The DfSSETA Apply for Landing application supports a fictional Apply for Landing service supplied by the (equally fictional) Department for Space Strategy and Extra-Terrestrial Affairs.

The non-fictional purpose of the application is to serve as a model application that provides a template for how services are designed and developed at dxw. The intention is to guide developers new to the organisation in the dxw approach to application development; to aid developers in honing their cross-language skills; to demonstrate the dxw approach to interested external parties; and to serve as a basis for experimentation and trying out new technologies and ideas in a principled and systematic way.

The fictional purpose is to allow pilots of interplanetary spacecraft to obtain landing permits for a variety of destinations (namely, moons and planets) within Earth's solar system.

Language Note

The Apply for Landing application is intended to serve as a reference model instantiated in several different languages (namely Kotlin, C#, Javascript, Python, and Ruby). This repository contains the Ruby version of the application.

Service Flow

Functionally, the Apply for Landing application user journey consists of the following stages:

  1. A start page informs the user of the purpose of the application and the information they will need to supply in the course of completing it.
  2. A spacecraft pilot selects a destination for their spacecraft journey. This destination must be a Landable Body (that is to say, a planet or a moon).
  3. The pilot chooses an arrival and a departure date for their visit.
  4. The pilot enters their personal details into the application, including their Pilot License Identifier
  5. The user supplies information about the spacecraft they will be piloting, including their Spacecraft Registration Identifier
  6. The completed application is then displayed in its entirety to allow the user to check for errors. At this point the user can either edit their answers or proceed to the next stage.
  7. The application issues a landing permit to the pilot.

Data validation is performed at each stage, preventing the user from continuing until all information has been supplied in the correct format. As a result, Stage 7 (approval) can be assumed to occur automatically once the first 6 stages are complete.

A separate journey allows DfSSETA officers to view and assess applications.

Terminology

See ADR 0012: Standard terminology for the Apply for Landing service for details of how we refer to the entities within this domain.

API

As well as the principal service, which is delivered using the GOV.UK Design System, a JSON API is offered to authorised users, such as arrival authorities on Landable Bodies. See the OpenAPI documentation. Authentication is by way of an API key, passed in a header, e.g.

curl "https://apply-for-landing-ruby-4492c2b72668.herokuapp.com/api/landing-applications" \
     -H 'X-API-KEY: my-secret-api-key'

Local development

For bundling JS and CSS you will need:

  • node LTS (18.12.0)
  • yarn used for managing JS packages rather than npm

The local development application is then run using bin/dev which asks foreman to run the app's Procfile.

Seeding

The database is seeded using the Seed Fu gem with seeds defined in db/fixtures as follows:

  • landable bodies: in all environments
  • landing applications: in development environment only

The seeding can be run manually with bundle exec rake db:seed_fu. This is run automatically on deployment to Heroku. See the Procfile.

Tests

Local unit and integration tests

Fast feedback loop

These tests (Rspec and Capybara) can be run at maximum speed with:

bundle exec rspec

To run individual API specs with auto-generation of the OpenAPI spec, you need to specify the use the Rswag "formatter" e.g:

bundle exec rspec  --format Rswag::Specs::SwaggerFormatter \
       spec/api/landing_applications_spec.rb

Full pre-commit checks

Before committing you should run our complete set of checks and tests.

This is especially important if working on the API code as we're using the Rswag tooling to generate our OpenAPI spec from the integration tests in spec/api.

Choose from either the dockerised or undockerised version of the supplied comprehensive test script which includes:

  • formatting files with prettier
  • checking scripts with shellcheck
  • linting Ruby files with standardrb
  • linting JS with eslint
  • linting CSS with stylelint
  • running automated test suite with rspec
  • running API specs and generating OpenAPI spec via the rswag_api_tests_with_docs rake task
  • analysing vulnerabilities in Ruby gems with brakeman

e.g.

./script/no-docker/test

End-to-end (E2E) tests

Our end-to-end tests live in a separate repo dxw/dfsseta-apply-for-landing-e2e and are written using Playwright.

They have their own repo as we intend to use the same set of tests to exercise each implementation of the Apply For Landing model application. i.e. to run against the Ruby implementation (here), the .NET version, the Node version etc.

See that repo for more info.

Each merge to the main branch triggers the E2E test suite, which run against the application deployed to Heroku

Deployment

The application is deployed to Heroku on each merge to main by way of a GitHub Action.

Environment variables

The following environment variables must be set on Heroku;

  • HOSTNAME: currently apply-for-landing-ruby-4492c2b72668.herokuapp.com (the "Web URL" is shown with heroku info)
  • API_KEY_HMAC_SECRET_KEY: the secret used for generating digests of API keys. Generate with SecureRandom.hex(32) for production use.