UNPKG

@sprucelabs/spruce-cli

Version:

Command line interface for building Spruce skills.

78 lines 3.69 kB
"use strict"; var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); const spruce_skill_utils_1 = require("@sprucelabs/spruce-skill-utils"); const test_utils_1 = require("@sprucelabs/test-utils"); const test_utils_2 = require("@sprucelabs/test-utils"); const AbstractSkillTest_1 = __importDefault(require("../../../tests/AbstractSkillTest")); class CreatingAThemeTest extends AbstractSkillTest_1.default { static skillCacheKey = 'views'; static async hasCreateThemeAction() { test_utils_1.assert.isFunction(this.Action('view', 'createTheme').execute); } static async syncsEventsFirst() { await this.getSkillFixture().registerCurrentSkill({ name: 'current skill in creating a theme', }); const results = await this.Action('view', 'createTheme').execute({}); test_utils_1.assert.isFalsy(results.errors); test_utils_1.assert.isTrue(spruce_skill_utils_1.diskUtil.doesFileExist(this.resolveHashSprucePath('events/events.contract.ts'))); } static async makesThemeFile() { test_utils_1.assert.isTrue(spruce_skill_utils_1.diskUtil.doesFileExist(this.getThemePath())); } static async makesValidThemeFile() { const imported = await this.Service('import').importDefault(this.getThemePath()); test_utils_1.assert.isTruthy(imported); test_utils_1.assert.isTrue('color1' in imported); } static async cantRunTwice() { const results = await this.Action('view', 'createTheme').execute({}); test_utils_1.assert.isTruthy(results.errors); test_utils_2.errorAssert.assertError(results.errors[0], 'THEME_EXISTS'); } static async doesNotSyncEventsIfAlreadySynced() { const emitter = this.emitter; let hitCount = 0; spruce_skill_utils_1.diskUtil.deleteFile(this.getThemePath()); await emitter.on('feature.will-execute', async (payload) => { const { featureCode, actionCode } = payload; if (featureCode === 'event' && actionCode === 'sync') { hitCount++; } }); await this.Action('view', 'createTheme').execute({}); test_utils_1.assert.isEqual(hitCount, 0); } static getThemePath() { return this.resolvePath('src', 'themes', 'skill.theme.ts'); } } exports.default = CreatingAThemeTest; __decorate([ (0, test_utils_1.test)() ], CreatingAThemeTest, "hasCreateThemeAction", null); __decorate([ (0, test_utils_1.test)() ], CreatingAThemeTest, "syncsEventsFirst", null); __decorate([ (0, test_utils_1.test)() ], CreatingAThemeTest, "makesThemeFile", null); __decorate([ (0, test_utils_1.test)() ], CreatingAThemeTest, "makesValidThemeFile", null); __decorate([ (0, test_utils_1.test)() ], CreatingAThemeTest, "cantRunTwice", null); __decorate([ (0, test_utils_1.test)() ], CreatingAThemeTest, "doesNotSyncEventsIfAlreadySynced", null); //# sourceMappingURL=CreatingATheme.test.js.map