0
Fork 0
mirror of https://github.com/logto-io/logto.git synced 2025-01-20 21:32:31 -05:00

feat(cli): add option to seed test data

This commit is contained in:
Gao Sun 2023-12-14 17:08:59 +08:00
parent 21dd11c92e
commit f5812b689d
No known key found for this signature in database
GPG key ID: 13EBE123E4773688
2 changed files with 69 additions and 6 deletions

View file

@ -7,9 +7,9 @@ import { consoleLog, oraPromise } from '../../../utils.js';
import { getLatestAlterationTimestamp } from '../alteration/index.js'; import { getLatestAlterationTimestamp } from '../alteration/index.js';
import { getAlterationDirectory } from '../alteration/utils.js'; import { getAlterationDirectory } from '../alteration/utils.js';
import { createTables, seedCloud, seedTables } from './tables.js'; import { createTables, seedCloud, seedTables, seedTest } from './tables.js';
export const seedByPool = async (pool: DatabasePool, cloud = false) => { export const seedByPool = async (pool: DatabasePool, cloud = false, test = false) => {
await pool.transaction(async (connection) => { await pool.transaction(async (connection) => {
// Check alteration scripts available in order to insert correct timestamp // Check alteration scripts available in order to insert correct timestamp
const latestTimestamp = await getLatestAlterationTimestamp(); const latestTimestamp = await getLatestAlterationTimestamp();
@ -29,10 +29,17 @@ export const seedByPool = async (pool: DatabasePool, cloud = false) => {
if (cloud) { if (cloud) {
await seedCloud(connection); await seedCloud(connection);
} }
if (test) {
await seedTest(connection);
}
}); });
}; };
const seed: CommandModule<Record<string, unknown>, { swe?: boolean; cloud?: boolean }> = { const seed: CommandModule<
Record<string, unknown>,
{ swe?: boolean; cloud?: boolean; test?: boolean }
> = {
command: 'seed [type]', command: 'seed [type]',
describe: 'Create database then seed tables and data', describe: 'Create database then seed tables and data',
builder: (yargs) => builder: (yargs) =>
@ -45,9 +52,12 @@ const seed: CommandModule<Record<string, unknown>, { swe?: boolean; cloud?: bool
.option('cloud', { .option('cloud', {
describe: 'Seed additional cloud data', describe: 'Seed additional cloud data',
type: 'boolean', type: 'boolean',
hidden: true, })
.option('test', {
describe: 'Seed additional test data',
type: 'boolean',
}), }),
handler: async ({ swe, cloud }) => { handler: async ({ swe, cloud, test }) => {
const pool = await createPoolAndDatabaseIfNeeded(); const pool = await createPoolAndDatabaseIfNeeded();
if (swe && (await doesConfigsTableExist(pool))) { if (swe && (await doesConfigsTableExist(pool))) {
@ -58,7 +68,7 @@ const seed: CommandModule<Record<string, unknown>, { swe?: boolean; cloud?: bool
} }
try { try {
await seedByPool(pool, cloud); await seedByPool(pool, cloud, test);
} catch (error: unknown) { } catch (error: unknown) {
consoleLog.error(error); consoleLog.error(error);
consoleLog.error( consoleLog.error(

View file

@ -14,8 +14,12 @@ import {
createCloudApi, createCloudApi,
createTenantApplicationRole, createTenantApplicationRole,
CloudScope, CloudScope,
Roles,
type Role,
UsersRoles,
} from '@logto/schemas'; } from '@logto/schemas';
import { Tenants } from '@logto/schemas/models'; import { Tenants } from '@logto/schemas/models';
import { convertToIdentifiers, generateStandardId } from '@logto/shared';
import type { DatabaseTransactionConnection } from 'slonik'; import type { DatabaseTransactionConnection } from 'slonik';
import { sql } from 'slonik'; import { sql } from 'slonik';
import { raw } from 'slonik-sql-tag-raw'; import { raw } from 'slonik-sql-tag-raw';
@ -176,3 +180,52 @@ export const seedCloud = async (connection: DatabaseTransactionConnection) => {
seedTenantCloudServiceApplication(connection, adminTenantId), seedTenantCloudServiceApplication(connection, adminTenantId),
]); ]);
}; };
/**
* Seed additional test data for integration or alteration tests.
*
* It will create two users to the admin tenant (`test-1` and `test-2`), and do the following:
*
* - `test-1` will be assigned the management roles for both `default` and `admin` tenant.
* - `test-2` will be assigned the management role for `default` tenant.
*/
export const seedTest = async (connection: DatabaseTransactionConnection) => {
const roles = convertToIdentifiers(Roles);
const getManagementRole = async (tenantId: string) =>
connection.one<Role>(sql`
select ${roles.fields.id}
from ${roles.table}
where ${roles.fields.tenantId} = ${adminTenantId}
and ${roles.fields.name} = ${`${tenantId}:admin`}
`);
const assignRoleToUser = async (userId: string, roleId: string) =>
connection.query(
insertInto(
{ id: generateStandardId(), userId, roleId, tenantId: adminTenantId },
UsersRoles.table
)
);
await Promise.all([
connection.query(
insertInto({ id: 'test-1', username: 'test1', tenantId: adminTenantId }, 'users')
),
connection.query(
insertInto({ id: 'test-2', username: 'test2', tenantId: adminTenantId }, 'users')
),
]);
consoleLog.succeed('Created test users');
const adminTenantRole = await getManagementRole(adminTenantId);
const defaultTenantRole = await getManagementRole(defaultTenantId);
await Promise.all([
assignRoleToUser('test-1', adminTenantRole.id),
assignRoleToUser('test-1', defaultTenantRole.id),
assignRoleToUser('test-2', defaultTenantRole.id),
]);
consoleLog.succeed('Assigned tenant management roles to the test users');
};