populate-for-testing.ts 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. /* tslint:disable:no-console */
  2. import { INestApplicationContext } from '@nestjs/common';
  3. import { LanguageCode } from '@vendure/common/lib/generated-types';
  4. import { VendureConfig } from '@vendure/core';
  5. import { importProductsFromCsv, populateCollections, populateInitialData } from '@vendure/core/cli';
  6. import { TestServerOptions } from '../types';
  7. import { populateCustomers } from './populate-customers';
  8. // tslint:disable:no-floating-promises
  9. /**
  10. * Clears all tables from the database and populates with (deterministic) random data.
  11. */
  12. export async function populateForTesting<T extends INestApplicationContext>(
  13. config: Required<VendureConfig>,
  14. bootstrapFn: (config: VendureConfig) => Promise<T>,
  15. options: TestServerOptions,
  16. ): Promise<T> {
  17. (config.dbConnectionOptions as any).logging = false;
  18. const logging = options.logging === undefined ? true : options.logging;
  19. const originalRequireVerification = config.authOptions.requireVerification;
  20. config.authOptions.requireVerification = false;
  21. const app = await bootstrapFn(config);
  22. const logFn = (message: string) => (logging ? console.log(message) : null);
  23. await populateInitialData(app, options.initialData);
  24. await populateProducts(app, options.productsCsvPath, logging);
  25. await populateCollections(app, options.initialData);
  26. await populateCustomers(app, options.customerCount ?? 10, logFn);
  27. config.authOptions.requireVerification = originalRequireVerification;
  28. return app;
  29. }
  30. async function populateProducts(app: INestApplicationContext, productsCsvPath: string, logging: boolean) {
  31. const importResult = await importProductsFromCsv(app, productsCsvPath, LanguageCode.en);
  32. if (importResult.errors && importResult.errors.length) {
  33. console.log(`${importResult.errors.length} errors encountered when importing product data:`);
  34. await console.log(importResult.errors.join('\n'));
  35. }
  36. if (logging) {
  37. console.log(`\nImported ${importResult.imported} products`);
  38. }
  39. }