Skip to content

Files

Latest commit

e96ce70 · Dec 23, 2024

History

History
112 lines (86 loc) · 2.94 KB

typescript.md

File metadata and controls

112 lines (86 loc) · 2.94 KB

Testplane × Typescript

To write Testplane tests on typescript, you would need to install ts-node:

npm i -D ts-node

And include Testplane types in your tsconfig.json file:

// tsconfig.json
{
    // other tsconfig options
    "compilerOptions": {
        // other compiler options
        "types": [
            // other types
            "testplane",
        ]
    }
}

Recommended config:

{
    "compilerOptions": {
        "types": [
            "testplane"
        ],
        "sourceMap": true,
        "outDir": "../test-dist",
        "target": "ESNext",
        "module": "CommonJS",
        "strict": true,
        "lib": ["esnext", "dom"],
        "esModuleInterop": true
    }
}

Note: this is the strictest possible setting, which works on Typescript 5.3+. If you want faster type-checks or have older Typescript version, use "skipLibCheck": true in compilerOptions.

testplane.ctx typings

If you want to extend testplane.ctx typings, you could use module augmentation:

import type { TestplaneCtx } from "testplane";

declare module "testplane" {
    interface TestplaneCtx {
        someVariable: string;
    }
}

Now testplane.ctx will have someVariable typings

Extending executionContext.ctx

executionContext.ctx is handy when you have some data specific to every test, and you want to share it across custom commands, test hooks and test body.

Let's see how it works in practice.

  1. Let's save something to executionContext.ctx in beforeEach global hook (provided by testplane-global-hook plugin):

    import type { TestFunctionCtx } from 'testplane';
    import { Api } from './api';
    
    beforeEach(async (this: TestFunctionCtx) => {
      // Assume this is some custom command you want to run before each test
      await this.browser.auth();
    
      // Assume after auth we have access to a cookie needed to make requests to API
      const sessionIdCookie = await this.getCookies(['Session_id']).then(cookies => cookies?.[0]?.value);
      const api = new Api(sessionIdCookie);
    
      // Now we want to make api available via executionContext.ctx
      this.api = api;
    })
  2. Access saved data in other places:

    // Assume we are implementing a custom command to get profile info
    export async function getProfileInfo() {
        const api = this.executionContext.ctx.api;
    
        return api.getProfileInfo();
    } 

This becomes useful when you have many commands utilising ctx. You don't need to make requests or get data over and over, you can do it once and save in ctx for future use.

Now, to make it type-safe in TypeScript, we could write the following module augmentation:

import type { TestplaneCtx } from "testplane";
import type { Api } from './api';

declare module "testplane" {
    interface ExecutionThreadCtx {
        api: Api;
    }
}

Now executionContext.ctx will include Api typings.