The cvs-svc-test-number microservice is used to generate and maintain sequence numbers as required by functional services.
The service supports generating:
- System Numbers for use on Test Results
- Test Numbers for use on Certificates
- Trailer IDs for use on Technical Records
The project runs on node >18.x with typescript and serverless framework. For further details about project dependencies, please refer to the package.json
file.
nvm is used to managed node versions and configuration explicitly done per project using an .npmrc
file.
Please install and run the following security program as part of your development process:
- git-secrets
After installing, do a one-time set up with
git secrets --register-aws
. Run withgit secrets --scan
.
This will be run as part of your projects hooks so you don't accidentally introduce any new security vulnerabilities.
Please refer to the the docs for the API specification and samples of postman requests.
More information about technical designs can be found under the Test Number Microservice section.
Set up your nodejs environment running nvm use
and once the dependencies are installed using npm i
, you can run the scripts from package.json
to build your project.
This code repository uses serverless framework to mock AWS capabilities for local development.
You will also require to install dynamodb serverless to run your project with by running the following command npm run tools-setup
in your preferred shell.
Once dynamoDB is installed, you will need a local serverless profile to be created so that you can start developping locally.
The profiles are stored under ~/.aws/credentials
.
# ~/.aws/credentials
# Please not only serverless is used to develop locally, not deployment of services are done with this framework
# It might look like this
[default]
aws_access_key_id=<yourDummyAccesskey>
aws_secret_access_key=<yourDummySecret>
Please refer to the local development section to configure your project locally.
The configuration file for the service can be found under src/config/config.yml
.
The real lambda function of this repository can be found under src/handler.ts
, and is a middleware function that calls lambda functions created by you according to the mapping declared in the configuration.
Here is an example:
functions:
- generateTestNumber:
method: POST
path: /test-number
proxy: null
function: generateTestNumber
- The
BRANCH
environment variable indicates in which environment is this application running. UseBRANCH=local
for local development. This variable is required when starting the application or running tests.
The following scripts are available, however you can refer to the package.json
to see the details:
- installing dependencies:
npm install
- local development by starting the service:
npm start
- building the project:
npm run build
- unit tests:
npm t
- integration tests:
npm run test-i
You won't need to change the configuration.
However, if you want the database to be populated with mock data on start, in your serverless.yml
file, you need to set seed
to true
. You can find this setting under custom > dynamodb > start
.
If you choose to run the DynamoDB instance separately, you can send the seed command with the following command:
sls dynamodb seed --seed=defects
Under custom > dynamodb > seed
you can define new seed operations with the following config:
custom:
dynamodb:
seed:
[SEED NAME HERE]:
sources:
- table: [TABLE TO SEED]
sources: [./path/to/resource.json]
Default DynamoDB configuration for seeding the data:
- migrate: true
seed: true
noStart: false
The following environmental variables can be given to your serverless scripts to trace and debug your service:
AWS_XRAY_CONTEXT_MISSING = LOG_ERROR
SLS_DEBUG = *
BRANCH = local
Jest is used for unit testing. Please refer to the Jest documentation for further details.
In order to test, you need to run the following:
npm run test # unit tests
In order to test, you need to run the following, with the service running locally:
npm run test-i # for integration tests
We follow a gitflow approach for development. For the CI/CD and automation please refer to the following pages for further details:
Please familiarise yourself with commitlint and conventional commits conventions as a hook is in place to enforce standards.
The projects has multiple hooks configured using husky which will execute the following scripts: security-checks
, audit
, tslint
, prepush
.
The codebase uses typescript clean code standards as well as sonarqube for static analysis.
SonarQube is available locally, please follow the instructions below if you wish to run the service locally (brew is the preferred approach).
Brew (recommended):
- Install sonarqube using brew
- Change
sonar.host.url
to point to localhost, by default, sonar runs onhttp://localhost:9000
- run the sonar server
sonar start
, then perform your analysisnpm run sonar-scanner
Manual:
- Download sonarqube
- Add sonar-scanner in environment variables in your profile file add the line:
export PATH=<PATH_TO_SONAR_SCANNER>/sonar-scanner-3.3.0.1492-macosx/bin:$PATH
- Start the SonarQube server:
cd <PATH_TO_SONARQUBE_SERVER>/bin/macosx-universal-64 ./sonar.sh start
- In the microservice folder run the command:
npm run sonar-scanner