populate.ts 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. /* tslint:disable:no-console */
  2. import { INestApplication } from '@nestjs/common';
  3. import fs from 'fs-extra';
  4. import path from 'path';
  5. import { LanguageCode } from '../../shared/generated-types';
  6. import { VendureBootstrapFunction } from '../src/bootstrap';
  7. import { setConfig } from '../src/config/config-helpers';
  8. import { VendureConfig } from '../src/config/vendure-config';
  9. import { clearAllTables } from './clear-all-tables';
  10. import { getDefaultChannelToken } from './get-default-channel-token';
  11. import { MockDataService } from './mock-data.service';
  12. import { SimpleGraphQLClient } from './simple-graphql-client';
  13. export interface PopulateOptions {
  14. logging?: boolean;
  15. customerCount: number;
  16. productsCsvPath: string;
  17. initialDataPath: string;
  18. }
  19. // tslint:disable:no-floating-promises
  20. /**
  21. * Clears all tables from the database and populates with (deterministic) random data.
  22. */
  23. export async function populate(
  24. config: VendureConfig,
  25. bootstrapFn: VendureBootstrapFunction,
  26. options: PopulateOptions,
  27. ): Promise<INestApplication> {
  28. (config.dbConnectionOptions as any).logging = false;
  29. const logging = options.logging === undefined ? true : options.logging;
  30. const originalRequireVerification = config.authOptions.requireVerification;
  31. config.authOptions.requireVerification = false;
  32. setConfig(config);
  33. await clearAllTables(config.dbConnectionOptions, logging);
  34. const app = await bootstrapFn(config);
  35. await populateInitialData(app, options.initialDataPath);
  36. await populateProducts(app, options.productsCsvPath, logging);
  37. const defaultChannelToken = await getDefaultChannelToken(logging);
  38. const client = new SimpleGraphQLClient(`http://localhost:${config.port}/${config.apiPath}`);
  39. client.setChannelToken(defaultChannelToken);
  40. await client.asSuperAdmin();
  41. const mockDataService = new MockDataService(client, logging);
  42. await mockDataService.populateCustomers(options.customerCount);
  43. config.authOptions.requireVerification = originalRequireVerification;
  44. return app;
  45. }
  46. async function populateInitialData(app: INestApplication, initialDataPath: string) {
  47. const { Populator } = await import('../src/data-import/providers/populator/populator');
  48. const { initialData } = await import(initialDataPath);
  49. const populator = app.get(Populator);
  50. try {
  51. await populator.populateInitialData(initialData);
  52. } catch (err) {
  53. console.error(err.message);
  54. }
  55. }
  56. async function populateProducts(app: INestApplication, productsCsvPath: string, logging: boolean) {
  57. const { Importer } = await import('../src/data-import/providers/importer/importer');
  58. const importer = app.get(Importer);
  59. const productData = await fs.readFile(productsCsvPath, 'utf-8');
  60. const importResult = await importer.parseAndImport(productData, LanguageCode.en, true).toPromise();
  61. if (importResult.errors && importResult.errors.length) {
  62. console.log(`${importResult.errors.length} errors encountered when importing product data:`);
  63. await console.log(importResult.errors.join('\n'));
  64. }
  65. if (logging) {
  66. console.log(`\nImported ${importResult.imported} products`);
  67. }
  68. }