- node needs to be installed. See nvmrc or the
engines
definition in package.json for version. - Coral uses pnpm (version 8) as a package manager. Read their official documentation how to install pnpm.
Step by step
- navigate to
/coral
- run
pnpm install
- run
pnpm add-precommit
the first time you install the repository to set the custom directory for our pre commit hooks. - add api mock for
getAuth
- run
pnpm dev-without-remote-api
to start the development mode. - Add mock for getAuth
Coral is only accessible for authenticated users. Without API, the call to /getAuth
that gets the user, you'll only see a loading animation.
Mocking the API response for that is necessary to access Coral:
- go to auth-user-api.ts
- In function
getAuth
, return a hard coded AuthUser for this function:
const testAuthUser: AuthUser = {
canSwitchTeams: "false",
teamId: "12345",
teamname: "NightsWatch",
username: "Jon Snow",
};
function getAuth(): Promise<AuthUser> {
return Promise.resolve(testAuthUser);
}
🙇 Please remember removing the mock before opening a PR for review :)
If all requirements are met, and you've done your first setup:
pnpm dev-without-api
- mocking the APIs you need
If you want to work on UI that needs data from an endpoint, you can mock the responses during the development process. This can be done by returning a resolved (or rejected) Promise
instead of executing the API call during development.
Example: mocking the response for getClusterInfoFromEnvironment
:
- go the
src/domain/cluster/cluster-api.ts
- check the return type of the function (
KlawApiResponse<"getClusterInfoFromEnv">
) in our automatically generated api definition to create the right object: (api.d.ts to create the right object. - return a promise with your data instead of calling the endpoint and comment out the actual endpoint call:
const getClusterInfoFromEnvironment = async ({
envSelected,
envType,
}: {
envSelected: string;
envType: Environment["type"];
}): Promise<KlawApiResponse<"getClusterInfoFromEnv">> => {
const mock: KlawApiResponse<"getClusterInfoFromEnv"> = {
aivenCluster: true,
};
return Promise.resolve(mock);
};
🙇 Please remember removing the mock before opening a PR for review :)