Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/dxw/dfsseta-apply-for-landing-ruby

The Ruby instance of the model Apply for Landing service
https://github.com/dxw/dfsseta-apply-for-landing-ruby

delivery-plus

Last synced: 21 days ago
JSON representation

The Ruby instance of the model Apply for Landing service

Awesome Lists containing this project

README

        

# 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](./doc/architecture/decisions/0012-standard-terminology.md)
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.

```sh
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](./Procfile).

## Tests

### Local unit and integration tests

#### Fast feedback loop

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

```sh
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:

```sh
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.

```sh
./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.

[Seed Fu gem]: https://github.com/mbleigh/seed-fu
[`dxw/dfsseta-apply-for-landing-e2e`]:
https://github.com/dxw/dfsseta-apply-for-landing-e2e
[GitHub Action]:
https://github.com/dxw/dfsseta-apply-for-landing-ruby/blob/main/.github/workflows/heroku-deployment.yml
[deployed to Heroku]: https://apply-for-landing-ruby-4492c2b72668.herokuapp.com/
[GOV.UK Design System]: https://design-system.service.gov.uk
[OpenAPI documentation]:
https://apply-for-landing-ruby-4492c2b72668.herokuapp.com/api-docs/