Skip to content

Latest commit

 

History

History

test-vectors

Web5 Test Vectors

Description

This directory contains test vectors for all features we intend to support accross several languages. Each feature has its own directory which contains a single vectors file per sub-feature e.g.

web5-test-vectors
├── README.md
├── did_jwk <--- feature
│   └── resolve.json <--- sub-feature
├── index.html
└── vectors.schema.json

Test Vector Files

Test vector files should adhere to vectors.schema.json. This repo contains a test-vector-validation script that validates all vectors files in this directory. It can be run manually by following the instructions here.

Note

Test Vector Validation runs automatically anytime a change is made in this directory or to the script itself.

Each test vector file is a structured collection of test vector objects, where each vector asserts a specific outcome for a given input. Below is a table that outlines the expected fields in a test vector file:

Field Type Description Required
description string A general description of the test vectors collection. Yes
vectors array An array of test vector objects. Yes
vectors[].description string A description of what this test vector is testing. Yes
vectors[].input any The input for the test vector, which can be of any type. Yes
vectors[].output any The expected output for the test vector, which can be of any type. No
vectors[].errors boolean Indicates whether the test vector is expected to produce an error. Defaults to false if not present. No

Rationale for Test Vector Structure

The structure of a vector object is designed to fulfill two conditions:

  • the function works and returns something that should match output
  • the function throws an error (in whatever way the consuming language represents errors)
    • optionally, the error's output should match output

errors: true is an instruction to anticipate an error in the implementation language. For example:

  • In languages like Kotlin or Javascript, the presence of errors: true would imply that assertThrows be used.
  • In Go, the expectation would be for the err variable to be non-nil.
  • In Rust, the error handling would pivot on matching Result.Err rather than Result.Ok.

Should errors be set to true, the output field may optionally be used to include expected error messages.

Creating New Test Vector Full Walkthrough

Step 1: Pull down the sdk repo with submouldes you are working with

  1. git clone --recurse-submodules git@github.com:TBD54566975/web5-kt.git

Or if you already cloned it, and just want to pull down the submodules:

  1. git submodule update --init

Step 2: Create New Test Vector in submodule folder

  1. Navigate to web5-spec in your local directory

  2. Create a new folder and JSON file with the structure example_feature/hello_world.json.

  3. Populate the JSON file as follows. Note that adherence to the json schema is enforced by CI.

{
  "description": "vector example",
  "vectors": [
    {
      "description": "this is an example",
      "input": "hello world",
      "output": "hello world",
      "errors": false
    }
  ]
}

Step 3: Create Unit Test

in Web5-kt

  1. In the web5-kt project, create a new unit test class.

  2. Name the class following the given pattern:

  • Prefix: Web5TestVectors

  • Middle: Convert example_feature to ExampleFeature (capitalize words and remove underscores)

  • Combined Output: Web5TestVectorsExampleFeature

  1. Implement the class and test method as follows:
class Web5TestVectorsExampleFeature {
  @Test
  fun hello_world() {
    val testVectors = mapper.readValue(File("../web5-spec/test-vectors/example_feature/hello_world.json"), typeRef)
    assertEquals(testVectors.vectors[0].input, testVectors.vectors[0].output)
  }
}

in Web5-js

  1. In the web5-js project, create a new unit test class.

  2. Name the class following the given pattern:

  • Prefix: Web5TestVectors

  • Middle: Convert example_feature to ExampleFeature (capitalize words and remove underscores)

  • Combined Output: Web5TestVectorsExampleFeature

  1. Implement the class and test method as follows:
  import ExampleFeatureHelloWorldSpecJson from '../../../web5-spec/test-vectors/example_feature/hello_world.json' assert { type: 'json' };

  describe('Web5TestVectorsExampleFeature', () => {
    it('hello_world', async () => {
      const vectors = ExampleFeatureHelloWorldSpecJson.vectors;
      expect(vectors[0].input).to.equal(vectors[0].output)
    });
  });

Step 4: Completion

  • Create a pr for the web5-spec submodules if you added new test vectors
  • Create a pr for the web5-* sdk to add the test vector new unit tests you created
  • The system will indicate whether the test passes or fails with a checkmark or an 'x' on the sdk-report-runner.

Your new test vector system is now set up and ready for use!