@wocker/testing 1.0.3 → 1.0.4-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/lib/index.d.ts CHANGED
@@ -1,3 +1,4 @@
1
1
  export * from "./makes";
2
2
  export * from "./modem";
3
3
  export * from "./services";
4
+ export * from "./utils";
package/lib/index.js CHANGED
@@ -17,3 +17,4 @@ Object.defineProperty(exports, "__esModule", { value: true });
17
17
  __exportStar(require("./makes"), exports);
18
18
  __exportStar(require("./modem"), exports);
19
19
  __exportStar(require("./services"), exports);
20
+ __exportStar(require("./utils"), exports);
@@ -1,7 +1,8 @@
1
- import { ApplicationContext, InjectionToken, ProviderType, Type, ModuleMetadata } from "@wocker/core";
1
+ import { ApplicationContext, InjectionToken, ProviderType, DynamicModule, Type, ModuleMetadata } from "@wocker/core";
2
2
  export declare class TestingModuleBuilder {
3
3
  protected readonly moduleType: Type;
4
4
  protected readonly overrideProviders: Map<InjectionToken, ProviderType>;
5
+ protected readonly overrideModules: Map<Type, Type | DynamicModule>;
5
6
  constructor(metadata: ModuleMetadata);
6
7
  protected createModule(metadata: ModuleMetadata): {
7
8
  new (): {};
@@ -10,5 +11,8 @@ export declare class TestingModuleBuilder {
10
11
  useProvider(type: ProviderType): TestingModuleBuilder;
11
12
  useValue(value: any): TestingModuleBuilder;
12
13
  };
14
+ overrideModule(module: Type): {
15
+ useModule: (newModule: Type | DynamicModule) => TestingModuleBuilder;
16
+ };
13
17
  build(): Promise<ApplicationContext>;
14
18
  }
@@ -13,6 +13,7 @@ class TestingModuleBuilder {
13
13
  constructor(metadata) {
14
14
  this.moduleType = this.createModule(metadata);
15
15
  this.overrideProviders = new Map();
16
+ this.overrideModules = new Map();
16
17
  this.overrideProvider(core_1.ProcessService)
17
18
  .useProvider(services_1.MockProcessService);
18
19
  }
@@ -41,9 +42,27 @@ class TestingModuleBuilder {
41
42
  }
42
43
  };
43
44
  }
45
+ overrideModule(module) {
46
+ const _this = this;
47
+ return {
48
+ useModule: (newModule) => {
49
+ this.overrideModules.set(module, newModule);
50
+ return _this;
51
+ }
52
+ };
53
+ }
44
54
  async build() {
45
55
  const _this = this;
46
56
  class TestScanner extends core_1.Scanner {
57
+ scanModule(moduleDefinition) {
58
+ const type = this.isDynamicModule(moduleDefinition)
59
+ ? moduleDefinition.module
60
+ : moduleDefinition;
61
+ if (_this.overrideModules.has(type)) {
62
+ return super.scanModule(_this.overrideModules.get(type));
63
+ }
64
+ return super.scanModule(moduleDefinition);
65
+ }
47
66
  scanRoutes() {
48
67
  _this.overrideProviders.forEach((provider, token) => {
49
68
  this.container.replace(token, provider);
@@ -0,0 +1 @@
1
+ export * from "./utilsMock";
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./utilsMock"), exports);
@@ -0,0 +1,12 @@
1
+ export declare const utilsMock: {
2
+ promptInput: ({ message }: {
3
+ message: any;
4
+ }) => any;
5
+ promptSelect: ({ message }: {
6
+ message: any;
7
+ }) => any;
8
+ promptConfirm: ({ message }: {
9
+ message: any;
10
+ }) => any;
11
+ setPromptMock: (map: any) => void;
12
+ };
@@ -0,0 +1,15 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.utilsMock = void 0;
4
+ let promptMap = {};
5
+ const prompt = ({ message }) => {
6
+ return promptMap[message];
7
+ };
8
+ exports.utilsMock = {
9
+ promptInput: prompt,
10
+ promptSelect: prompt,
11
+ promptConfirm: prompt,
12
+ setPromptMock: (map) => {
13
+ promptMap = map;
14
+ }
15
+ };
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@wocker/testing",
3
3
  "type": "commonjs",
4
- "version": "1.0.3",
4
+ "version": "1.0.4-beta.0",
5
5
  "author": "Kris Papercut <krispcut@gmail.com>",
6
6
  "description": "Docker workspace for web projects (testing)",
7
7
  "license": "MIT",