Skip to content

Latest commit

 

History

History
197 lines (133 loc) · 8.71 KB

File metadata and controls

197 lines (133 loc) · 8.71 KB

openactive-integration-tests

This Node.js script runs tests against the specified openactive-broker-microservice instance

Test coverage

See Feature Test Coverage for full details.

Model results

The results of this test suite when run against the reference implementation can be found:

Usage in separate terminal windows

To run openactive-integration-tests in separate terminal window to openactive-broker-microservice, from repository root:

  1. Ensure the openactive-broker-microservice is running in another terminal window
  2. Specify Configuration file: export NODE_ENV=dev
    • This is the command to use if using the dev.json config file. See Configuration for more details)
  3. Run Tests: npm run start-tests

Running specific tests

npm run start-tests -- test/features/core/availability-check/implemented/availability-confirmed-test.js

Running core tests in a single process

npm run start-tests -- --runInBand test/features/core/

Configuration for integrationTests within ./config/{NODE_ENV}.json

The integrationTests object within the ./config/{NODE_ENV}.json file of the repository configures which tests are run. This object includes the properties listed below, and should be configured to match the features of the booking system under test.

useRandomOpportunities

  • "useRandomOpportunities": true: Opportunities that match the prerequisite criteria for each test must exist in the booking system for the configured primary Seller. These opportunities will be chosen at random, and used for each test. Note that opportunities are not reused between tests within the same run of the test suite.
  • "useRandomOpportunities": false: The test interface of the booking system is used to create prerequisite opportunities before each test is run, based on the supplied testOpportunityCriteria.

requestHeaderLogging

Set this property to true to capture request headers in the markdown logs, which can be useful for debugging authentication.

It is recommended that this property be set to false when generating conformance certificates, for security.

bookableOpportunityTypesInScope

Tests will be repeated for each opportunity type that is set to true. Multiple OrderItem tests will include a mixture of the opportunity types set to true.

  "bookableOpportunityTypesInScope": {
    "ScheduledSession": true,
    "FacilityUseSlot": false,
    "IndividualFacilityUseSlot": false,
    "CourseInstance": false,
    "CourseInstanceSubEvent": false,
    "HeadlineEvent": false,
    "HeadlineEventSubEvent": false,
    "Event": false,
    "OnDemandEvent": false
  },

bookingFlowsInScope

Like bookableOpportunityTypesInScope, tests will be repeated for each of the Booking Flows that are set to true.

  "bookingFlowsInScope": {
    "OpenBookingSimpleFlow": true,
    "OpenBookingApprovalFlow": false
  }

The different Booking Flows represent the order of API endpoints (and actions) that must be invoked in order to complete a booking. They are:

This combination of Booking Flows also stacks up with the combination of Opportunity Types:

  "bookableOpportunityTypesInScope": {
    "ScheduledSession": true,
    "FacilityUseSlot": true
  },
  "bookingFlowsInScope": {
    "OpenBookingSimpleFlow": true,
    "OpenBookingApprovalFlow": true
  }

In the example above, all of the implemented features would be tested 4 times. Once for ScheduledSessions with the Simple Booking Flow, once for ScheduledSessions with the Approval Flow, etc.

implementedFeatures

The value of each feature in the map determines the tests that will be run:

  • true: Runs the 'Implemented' tests for the feature.
  • false: Runs the 'Not Implemented' tests for the feature, to confirm that the booking system behaviour is consistent with expectations for when the feature is not implemented.
  • null: Does not run any tests for this feature, useful for debugging.
  "implementedFeatures": {
    "opportunity-feed": true,
    "dataset-site": true,
    "availability-check": true,
    ...
  }

testDatasetIdentifier

This identifier is useful where the test interface implementation is shared between different instances of openactive-integration-tests. It allows any test data that was created with this identifier to be cleared before a new test run begins, without effecting test data created with other identifiers.

This value is passed into the test interface of either the broker microservice (when "useRandomOpportunities": true), or of the booking system (when "useRandomOpportunities": false).

The value can be any string, such as uat-ci, or alex-dev.

outputPath

Test results are written to *.md within the directory specified by outputPath in Markdown format.

useShapeExpressions

Whether or not to use the experimental Shape Expressions feature (introduced in this Test Interface issue) to improve the process of requesting data matching a specific criteria.

This is off by default as it is currently an experimental feature which has not yet been included in the Test Interface specification.

If turned on, you may be able to build a simpler and more extensible:

  "useShapeExpressions": false

ignoreUnexpectedFeedUpdates

Whether or not to use the experimental Listener Item Expectations feature (introduced in this issue). This experimental feature is not advised as 1). it is not yet fully implemented across all tests, and 2). it may lead to confusing results when a test fails (as is discussed in the issue).

It is false by default.

If turned on, Broker Microservice will be more picky when listening for updates in the Orders Feeds or Opportunity Feeds. Specifically, it will ignore feed updates which it was not expecting.

This is necessary if the booking system under test produces RPDE feed updates which are additional to (and irrelevant to) the updates that the tests are listening for.

  "ignoreUnexpectedFeedUpdates": false

Reading test results

To read the markdown files that are written to the directory specified by outputPath, the Markdown Viewer Chrome Extension is recommended, with the following settings:

  • CONTENT -> "autoreload" on
  • ADVANCED OPTIONS -> ALLOW ACCESS TO FILE:// URLS (links to setting in Chrome Extensions settings of the same name)

Use Ctrl+F within the browser and search for "❌️" to jump to the first error on the page, both within the summary.md file, and within the individual test results linked from the summary.

Development

See DEVELOPMENT.md for info on how the flow validations are written.

See ARCHITECTURE.md for information on the various components and how they tie together.

Debugging tests

npm start -- --reporters default

Debugging tests in VSCode

In order to debug an individual test using VSCode, so you can place breakpoints, inspect values and step through the code in your editor, add a launch configuration to .vscode/launch.json that looks like the following:

{
  "name": "integration-tests - {{ nameOfTest }}",
  "request": "launch",
  "runtimeArgs": [
    "run-script",
    "start-tests",
    "--",
    "--runInBand",
    "{{ pathToTest }}"
  ],
  "runtimeExecutable": "npm",
  "skipFiles": [
    "<node_internals>/**"
  ],
  "type": "node"
},

Example values:

  • nameOfTest: core/amending-order-quote/amend-c1
  • pathToTest: test/features/core/amending-order-quote/implemented/amend-c1-test.js