Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@squiz/dxp-ai-client

Package Overview
Dependencies
Maintainers
50
Versions
32
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@squiz/dxp-ai-client - npm Package Compare versions

Comparing version 0.20.0 to 0.20.1

6

CHANGELOG.md
# @squiz/dxp-ai-client
## 0.20.1
### Patch Changes
- 5ee41b8: Fixed issue where command executor wouldn't reject if outputs from execution could not be fetched.
## 0.20.0

@@ -4,0 +10,0 @@

11

dist/utils/CommandExecutor/AbstractCommandExecutor.js

@@ -15,3 +15,10 @@ "use strict";

setTimeout(async () => {
const result = await fetch();
let result;
try {
result = await fetch();
}
catch (error) {
reject(error);
return;
}
switch (result.status) {

@@ -40,2 +47,2 @@ case 'executing':

exports.AbstractCommandExecutor = AbstractCommandExecutor;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQWJzdHJhY3RDb21tYW5kRXhlY3V0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdXRpbHMvQ29tbWFuZEV4ZWN1dG9yL0Fic3RyYWN0Q29tbWFuZEV4ZWN1dG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUdBLE1BQXNCLHVCQUF1QjtJQUl0QjtJQUNBO0lBSmIsTUFBTSxDQUFDLHlCQUF5QixHQUFHLElBQUksQ0FBQztJQUVoRCxZQUNxQixNQUFvQixFQUNwQixVQUFtQyxFQUFFO1FBRHJDLFdBQU0sR0FBTixNQUFNLENBQWM7UUFDcEIsWUFBTyxHQUFQLE9BQU8sQ0FBOEI7SUFDdkQsQ0FBQztJQUlNLEtBQUssQ0FBQywwQkFBMEIsQ0FDeEMsV0FBbUIsRUFDbkIsS0FBdUI7UUFFdkIsT0FBTyxJQUFJLE9BQU8sQ0FBQyxDQUFDLE9BQU8sRUFBRSxNQUFNLEVBQUUsRUFBRTtZQUNyQyxVQUFVLENBQUMsS0FBSyxJQUFJLEVBQUU7Z0JBQ3BCLE1BQU0sTUFBTSxHQUFHLE1BQU0sS0FBSyxFQUFFLENBQUM7Z0JBRTdCLFFBQVEsTUFBTSxDQUFDLE1BQU0sRUFBRSxDQUFDO29CQUN0QixLQUFLLFdBQVcsQ0FBQztvQkFDakIsS0FBSyxTQUFTO3dCQUNaLE9BQU8sQ0FBQyxJQUFJLENBQUMsMEJBQTBCLENBQUMsV0FBVyxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUM7d0JBQzdELE1BQU07b0JBQ1IsS0FBSyxXQUFXO3dCQUNkLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQzt3QkFDaEIsTUFBTTtvQkFDUixLQUFLLFFBQVE7d0JBQ1gsTUFBTSxDQUFDLElBQUksS0FBSyxDQUFDLHNCQUFzQixXQUFXLFdBQVcsQ0FBQyxDQUFDLENBQUM7d0JBQ2hFLE1BQU07b0JBQ1IsS0FBSyxXQUFXO3dCQUNkLE1BQU0sQ0FBQyxJQUFJLEtBQUssQ0FBQyxzQkFBc0IsV0FBVyxrQkFBa0IsQ0FBQyxDQUFDLENBQUM7d0JBQ3ZFLE1BQU07b0JBQ1I7d0JBQ0UsTUFBTSxDQUFDLElBQUksS0FBSyxDQUFDLHNCQUFzQixXQUFXLGtDQUFrQyxNQUFNLENBQUMsTUFBTSxJQUFJLENBQUMsQ0FBQyxDQUFDO3dCQUN4RyxNQUFNO2dCQUNWLENBQUM7WUFDSCxDQUFDLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxlQUFlLElBQUksdUJBQXVCLENBQUMseUJBQXlCLENBQUMsQ0FBQztRQUN4RixDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7O0FBdENILDBEQXVDQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFwaSwgRXhlY3V0aW9uT3V0cHV0c1Jlc3BvbnNlIH0gZnJvbSAnLi4vLi4vZ2VuZXJhdGVkL0R4cEFpU2VydmljZSc7XG5pbXBvcnQgeyBDb21tYW5kRXhlY3V0aW9uT3B0aW9ucywgRXhlY3V0aW9uSW5wdXRzLCBFeGVjdXRpb25SZXN1bHQgfSBmcm9tICcuL0Fic3RyYWN0Q29tbWFuZEV4ZWN1dG9yLnR5cGVzJztcblxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEFic3RyYWN0Q29tbWFuZEV4ZWN1dG9yPFRDb21tYW5kPiB7XG4gIHByaXZhdGUgc3RhdGljIERFRkFVTFRfUE9MTF9GUkVRVUVOQ1lfTVMgPSAzMDAwO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHByb3RlY3RlZCByZWFkb25seSBjbGllbnQ6IEFwaTx1bmtub3duPixcbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgb3B0aW9uczogQ29tbWFuZEV4ZWN1dGlvbk9wdGlvbnMgPSB7fSxcbiAgKSB7fVxuXG4gIHB1YmxpYyBhYnN0cmFjdCBleGVjdXRlKGFpSWQ6IHN0cmluZywgY29tbWFuZDogVENvbW1hbmQsIGlucHV0czogRXhlY3V0aW9uSW5wdXRzKTogUHJvbWlzZTxFeGVjdXRpb25SZXN1bHQ+O1xuXG4gIHByb3RlY3RlZCBhc3luYyB3YWl0VW50aWxFeGVjdXRpb25Db21wbGV0ZTxUIGV4dGVuZHMgRXhlY3V0aW9uT3V0cHV0c1Jlc3BvbnNlPihcbiAgICBleGVjdXRpb25JZDogc3RyaW5nLFxuICAgIGZldGNoOiAoKSA9PiBQcm9taXNlPFQ+LFxuICApOiBQcm9taXNlPFQ+IHtcbiAgICByZXR1cm4gbmV3IFByb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgICAgc2V0VGltZW91dChhc3luYyAoKSA9PiB7XG4gICAgICAgIGNvbnN0IHJlc3VsdCA9IGF3YWl0IGZldGNoKCk7XG5cbiAgICAgICAgc3dpdGNoIChyZXN1bHQuc3RhdHVzKSB7XG4gICAgICAgICAgY2FzZSAnZXhlY3V0aW5nJzpcbiAgICAgICAgICBjYXNlICdwZW5kaW5nJzpcbiAgICAgICAgICAgIHJlc29sdmUodGhpcy53YWl0VW50aWxFeGVjdXRpb25Db21wbGV0ZShleGVjdXRpb25JZCwgZmV0Y2gpKTtcbiAgICAgICAgICAgIGJyZWFrO1xuICAgICAgICAgIGNhc2UgJ3N1Y2NlZWRlZCc6XG4gICAgICAgICAgICByZXNvbHZlKHJlc3VsdCk7XG4gICAgICAgICAgICBicmVhaztcbiAgICAgICAgICBjYXNlICdmYWlsZWQnOlxuICAgICAgICAgICAgcmVqZWN0KG5ldyBFcnJvcihgRXhlY3V0aW9uIHdpdGggSUQgXCIke2V4ZWN1dGlvbklkfVwiIGZhaWxlZC5gKSk7XG4gICAgICAgICAgICBicmVhaztcbiAgICAgICAgICBjYXNlICdjYW5jZWxsZWQnOlxuICAgICAgICAgICAgcmVqZWN0KG5ldyBFcnJvcihgRXhlY3V0aW9uIHdpdGggSUQgXCIke2V4ZWN1dGlvbklkfVwiIHdhcyBjYW5jZWxsZWQuYCkpO1xuICAgICAgICAgICAgYnJlYWs7XG4gICAgICAgICAgZGVmYXVsdDpcbiAgICAgICAgICAgIHJlamVjdChuZXcgRXJyb3IoYEV4ZWN1dGlvbiB3aXRoIElEIFwiJHtleGVjdXRpb25JZH1cIiBoYXMgYW4gdW5leHBlY3RlZCBzdGF0dXMgb2YgXCIke3Jlc3VsdC5zdGF0dXN9XCIuYCkpO1xuICAgICAgICAgICAgYnJlYWs7XG4gICAgICAgIH1cbiAgICAgIH0sIHRoaXMub3B0aW9ucy5wb2xsRnJlcXVlbmN5TXMgfHwgQWJzdHJhY3RDb21tYW5kRXhlY3V0b3IuREVGQVVMVF9QT0xMX0ZSRVFVRU5DWV9NUyk7XG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQWJzdHJhY3RDb21tYW5kRXhlY3V0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdXRpbHMvQ29tbWFuZEV4ZWN1dG9yL0Fic3RyYWN0Q29tbWFuZEV4ZWN1dG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUdBLE1BQXNCLHVCQUF1QjtJQUl0QjtJQUNBO0lBSmIsTUFBTSxDQUFDLHlCQUF5QixHQUFHLElBQUksQ0FBQztJQUVoRCxZQUNxQixNQUFvQixFQUNwQixVQUFtQyxFQUFFO1FBRHJDLFdBQU0sR0FBTixNQUFNLENBQWM7UUFDcEIsWUFBTyxHQUFQLE9BQU8sQ0FBOEI7SUFDdkQsQ0FBQztJQUlNLEtBQUssQ0FBQywwQkFBMEIsQ0FDeEMsV0FBbUIsRUFDbkIsS0FBdUI7UUFFdkIsT0FBTyxJQUFJLE9BQU8sQ0FBQyxDQUFDLE9BQU8sRUFBRSxNQUFNLEVBQUUsRUFBRTtZQUNyQyxVQUFVLENBQUMsS0FBSyxJQUFJLEVBQUU7Z0JBQ3BCLElBQUksTUFBUyxDQUFDO2dCQUVkLElBQUksQ0FBQztvQkFDSCxNQUFNLEdBQUcsTUFBTSxLQUFLLEVBQUUsQ0FBQztnQkFDekIsQ0FBQztnQkFBQyxPQUFPLEtBQWMsRUFBRSxDQUFDO29CQUN4QixNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7b0JBQ2QsT0FBTztnQkFDVCxDQUFDO2dCQUVELFFBQVEsTUFBTSxDQUFDLE1BQU0sRUFBRSxDQUFDO29CQUN0QixLQUFLLFdBQVcsQ0FBQztvQkFDakIsS0FBSyxTQUFTO3dCQUNaLE9BQU8sQ0FBQyxJQUFJLENBQUMsMEJBQTBCLENBQUMsV0FBVyxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUM7d0JBQzdELE1BQU07b0JBQ1IsS0FBSyxXQUFXO3dCQUNkLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQzt3QkFDaEIsTUFBTTtvQkFDUixLQUFLLFFBQVE7d0JBQ1gsTUFBTSxDQUFDLElBQUksS0FBSyxDQUFDLHNCQUFzQixXQUFXLFdBQVcsQ0FBQyxDQUFDLENBQUM7d0JBQ2hFLE1BQU07b0JBQ1IsS0FBSyxXQUFXO3dCQUNkLE1BQU0sQ0FBQyxJQUFJLEtBQUssQ0FBQyxzQkFBc0IsV0FBVyxrQkFBa0IsQ0FBQyxDQUFDLENBQUM7d0JBQ3ZFLE1BQU07b0JBQ1I7d0JBQ0UsTUFBTSxDQUFDLElBQUksS0FBSyxDQUFDLHNCQUFzQixXQUFXLGtDQUFrQyxNQUFNLENBQUMsTUFBTSxJQUFJLENBQUMsQ0FBQyxDQUFDO3dCQUN4RyxNQUFNO2dCQUNWLENBQUM7WUFDSCxDQUFDLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxlQUFlLElBQUksdUJBQXVCLENBQUMseUJBQXlCLENBQUMsQ0FBQztRQUN4RixDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7O0FBN0NILDBEQThDQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFwaSwgRXhlY3V0aW9uT3V0cHV0c1Jlc3BvbnNlIH0gZnJvbSAnLi4vLi4vZ2VuZXJhdGVkL0R4cEFpU2VydmljZSc7XG5pbXBvcnQgeyBDb21tYW5kRXhlY3V0aW9uT3B0aW9ucywgRXhlY3V0aW9uSW5wdXRzLCBFeGVjdXRpb25SZXN1bHQgfSBmcm9tICcuL0Fic3RyYWN0Q29tbWFuZEV4ZWN1dG9yLnR5cGVzJztcblxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEFic3RyYWN0Q29tbWFuZEV4ZWN1dG9yPFRDb21tYW5kPiB7XG4gIHByaXZhdGUgc3RhdGljIERFRkFVTFRfUE9MTF9GUkVRVUVOQ1lfTVMgPSAzMDAwO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHByb3RlY3RlZCByZWFkb25seSBjbGllbnQ6IEFwaTx1bmtub3duPixcbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgb3B0aW9uczogQ29tbWFuZEV4ZWN1dGlvbk9wdGlvbnMgPSB7fSxcbiAgKSB7fVxuXG4gIHB1YmxpYyBhYnN0cmFjdCBleGVjdXRlKGFpSWQ6IHN0cmluZywgY29tbWFuZDogVENvbW1hbmQsIGlucHV0czogRXhlY3V0aW9uSW5wdXRzKTogUHJvbWlzZTxFeGVjdXRpb25SZXN1bHQ+O1xuXG4gIHByb3RlY3RlZCBhc3luYyB3YWl0VW50aWxFeGVjdXRpb25Db21wbGV0ZTxUIGV4dGVuZHMgRXhlY3V0aW9uT3V0cHV0c1Jlc3BvbnNlPihcbiAgICBleGVjdXRpb25JZDogc3RyaW5nLFxuICAgIGZldGNoOiAoKSA9PiBQcm9taXNlPFQ+LFxuICApOiBQcm9taXNlPFQ+IHtcbiAgICByZXR1cm4gbmV3IFByb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgICAgc2V0VGltZW91dChhc3luYyAoKSA9PiB7XG4gICAgICAgIGxldCByZXN1bHQ6IFQ7XG5cbiAgICAgICAgdHJ5IHtcbiAgICAgICAgICByZXN1bHQgPSBhd2FpdCBmZXRjaCgpO1xuICAgICAgICB9IGNhdGNoIChlcnJvcjogdW5rbm93bikge1xuICAgICAgICAgIHJlamVjdChlcnJvcik7XG4gICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG5cbiAgICAgICAgc3dpdGNoIChyZXN1bHQuc3RhdHVzKSB7XG4gICAgICAgICAgY2FzZSAnZXhlY3V0aW5nJzpcbiAgICAgICAgICBjYXNlICdwZW5kaW5nJzpcbiAgICAgICAgICAgIHJlc29sdmUodGhpcy53YWl0VW50aWxFeGVjdXRpb25Db21wbGV0ZShleGVjdXRpb25JZCwgZmV0Y2gpKTtcbiAgICAgICAgICAgIGJyZWFrO1xuICAgICAgICAgIGNhc2UgJ3N1Y2NlZWRlZCc6XG4gICAgICAgICAgICByZXNvbHZlKHJlc3VsdCk7XG4gICAgICAgICAgICBicmVhaztcbiAgICAgICAgICBjYXNlICdmYWlsZWQnOlxuICAgICAgICAgICAgcmVqZWN0KG5ldyBFcnJvcihgRXhlY3V0aW9uIHdpdGggSUQgXCIke2V4ZWN1dGlvbklkfVwiIGZhaWxlZC5gKSk7XG4gICAgICAgICAgICBicmVhaztcbiAgICAgICAgICBjYXNlICdjYW5jZWxsZWQnOlxuICAgICAgICAgICAgcmVqZWN0KG5ldyBFcnJvcihgRXhlY3V0aW9uIHdpdGggSUQgXCIke2V4ZWN1dGlvbklkfVwiIHdhcyBjYW5jZWxsZWQuYCkpO1xuICAgICAgICAgICAgYnJlYWs7XG4gICAgICAgICAgZGVmYXVsdDpcbiAgICAgICAgICAgIHJlamVjdChuZXcgRXJyb3IoYEV4ZWN1dGlvbiB3aXRoIElEIFwiJHtleGVjdXRpb25JZH1cIiBoYXMgYW4gdW5leHBlY3RlZCBzdGF0dXMgb2YgXCIke3Jlc3VsdC5zdGF0dXN9XCIuYCkpO1xuICAgICAgICAgICAgYnJlYWs7XG4gICAgICAgIH1cbiAgICAgIH0sIHRoaXMub3B0aW9ucy5wb2xsRnJlcXVlbmN5TXMgfHwgQWJzdHJhY3RDb21tYW5kRXhlY3V0b3IuREVGQVVMVF9QT0xMX0ZSRVFVRU5DWV9NUyk7XG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==

@@ -81,4 +81,14 @@ "use strict";

});
it('Throws if fetching the execution outputs fails', async () => {
const aiId = 'mock-ai-id';
const executionId = 'mock-execution-id';
const command = 'processChatMessage';
const inputs = { query: 'space facts' };
const error = new Error('Failed to fetch execution outputs.');
jest.spyOn(client.chatbotExecution, 'execute').mockResolvedValue({ executionId });
jest.spyOn(client.chatbotExecution, 'getExecutionOutput').mockRejectedValue(error);
await expect(commandExecutor.execute(aiId, command, inputs)).rejects.toThrow(error);
});
});
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ChatBotCommandExecutor.spec.js","sourceRoot":"","sources":["../../../src/utils/CommandExecutor/ChatBotCommandExecutor.spec.ts"],"names":[],"mappings":"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","sourcesContent":["import { Api, FlowsGetExecutionOutputsStatusEnum, HttpClient } from '../../generated/DxpAiService';\nimport { ChatBotCommandExecutor } from './ChatBotCommandExecutor';\n\ndescribe('ChatBotCommandExecutor', () => {\n  let client: Api<unknown>;\n  let commandExecutor: ChatBotCommandExecutor;\n\n  beforeEach(() => {\n    client = new Api({} as HttpClient);\n    commandExecutor = new ChatBotCommandExecutor(client);\n\n    jest.spyOn(global, 'setTimeout').mockImplementation((callback) => {\n      callback();\n      // eslint-disable-next-line\n      return 0 as any;\n    });\n  });\n\n  describe('.execute()', () => {\n    it('Resolves with the outputs of the execution', async () => {\n      const aiId = 'mock-ai-id';\n      const executionId = 'mock-execution-id';\n      const command = 'processChatMessage';\n      const inputs = { query: 'help me' };\n      const outputs = { message: 'informative response' };\n\n      jest.spyOn(client.chatbotExecution, 'execute').mockResolvedValue({ executionId });\n      jest\n        .spyOn(client.chatbotExecution, 'getExecutionOutput')\n        .mockResolvedValueOnce({\n          status: 'pending',\n          outputs: {},\n          finishedAt: null,\n          startedAt: null,\n        })\n        .mockResolvedValueOnce({\n          status: 'executing',\n          outputs: {},\n          finishedAt: null,\n          startedAt: 'mock-started-at',\n        })\n        .mockResolvedValueOnce({\n          status: 'succeeded',\n          outputs,\n          finishedAt: 'mock-finished-at',\n          startedAt: 'mock-started-at',\n        });\n\n      const result = await commandExecutor.execute(aiId, command, inputs);\n\n      expect(result).toEqual({\n        status: 'succeeded',\n        outputs,\n        finishedAt: 'mock-finished-at',\n        startedAt: 'mock-started-at',\n      });\n      expect(client.chatbotExecution.execute).toHaveBeenCalledWith(aiId, command, { inputs });\n      expect(client.chatbotExecution.getExecutionOutput).toHaveBeenCalledTimes(3);\n      expect(client.chatbotExecution.getExecutionOutput).toHaveBeenCalledWith(aiId, command, executionId);\n    });\n\n    it.each([\n      ['fails', 'failed' as FlowsGetExecutionOutputsStatusEnum, 'Execution with ID \"mock-execution-id\" failed.'],\n      [\n        'is cancelled',\n        'cancelled' as FlowsGetExecutionOutputsStatusEnum,\n        'Execution with ID \"mock-execution-id\" was cancelled.',\n      ],\n      [\n        'has an unknown status',\n        'unknown' as FlowsGetExecutionOutputsStatusEnum,\n        'Execution with ID \"mock-execution-id\" has an unexpected status of \"unknown\".',\n      ],\n    ])(\n      'Throws if the execution %s',\n      async (description: string, status: FlowsGetExecutionOutputsStatusEnum, expectedError: string) => {\n        const aiId = 'mock-ai-id';\n        const executionId = 'mock-execution-id';\n        const command = 'processChatMessage';\n        const inputs = { query: 'space facts' };\n\n        jest.spyOn(client.chatbotExecution, 'execute').mockResolvedValue({ executionId });\n        jest.spyOn(client.chatbotExecution, 'getExecutionOutput').mockResolvedValueOnce({\n          status,\n          outputs: {},\n          finishedAt: 'mock-finished-at',\n          startedAt: 'mock-started-at',\n        });\n\n        await expect(commandExecutor.execute(aiId, command, inputs)).rejects.toThrow(expectedError);\n      },\n    );\n  });\n});\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ChatBotCommandExecutor.spec.js","sourceRoot":"","sources":["../../../src/utils/CommandExecutor/ChatBotCommandExecutor.spec.ts"],"names":[],"mappings":"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","sourcesContent":["import { Api, FlowsGetExecutionOutputsStatusEnum, HttpClient } from '../../generated/DxpAiService';\nimport { ChatBotCommandExecutor } from './ChatBotCommandExecutor';\n\ndescribe('ChatBotCommandExecutor', () => {\n  let client: Api<unknown>;\n  let commandExecutor: ChatBotCommandExecutor;\n\n  beforeEach(() => {\n    client = new Api({} as HttpClient);\n    commandExecutor = new ChatBotCommandExecutor(client);\n\n    jest.spyOn(global, 'setTimeout').mockImplementation((callback) => {\n      callback();\n      // eslint-disable-next-line\n      return 0 as any;\n    });\n  });\n\n  describe('.execute()', () => {\n    it('Resolves with the outputs of the execution', async () => {\n      const aiId = 'mock-ai-id';\n      const executionId = 'mock-execution-id';\n      const command = 'processChatMessage';\n      const inputs = { query: 'help me' };\n      const outputs = { message: 'informative response' };\n\n      jest.spyOn(client.chatbotExecution, 'execute').mockResolvedValue({ executionId });\n      jest\n        .spyOn(client.chatbotExecution, 'getExecutionOutput')\n        .mockResolvedValueOnce({\n          status: 'pending',\n          outputs: {},\n          finishedAt: null,\n          startedAt: null,\n        })\n        .mockResolvedValueOnce({\n          status: 'executing',\n          outputs: {},\n          finishedAt: null,\n          startedAt: 'mock-started-at',\n        })\n        .mockResolvedValueOnce({\n          status: 'succeeded',\n          outputs,\n          finishedAt: 'mock-finished-at',\n          startedAt: 'mock-started-at',\n        });\n\n      const result = await commandExecutor.execute(aiId, command, inputs);\n\n      expect(result).toEqual({\n        status: 'succeeded',\n        outputs,\n        finishedAt: 'mock-finished-at',\n        startedAt: 'mock-started-at',\n      });\n      expect(client.chatbotExecution.execute).toHaveBeenCalledWith(aiId, command, { inputs });\n      expect(client.chatbotExecution.getExecutionOutput).toHaveBeenCalledTimes(3);\n      expect(client.chatbotExecution.getExecutionOutput).toHaveBeenCalledWith(aiId, command, executionId);\n    });\n\n    it.each([\n      ['fails', 'failed' as FlowsGetExecutionOutputsStatusEnum, 'Execution with ID \"mock-execution-id\" failed.'],\n      [\n        'is cancelled',\n        'cancelled' as FlowsGetExecutionOutputsStatusEnum,\n        'Execution with ID \"mock-execution-id\" was cancelled.',\n      ],\n      [\n        'has an unknown status',\n        'unknown' as FlowsGetExecutionOutputsStatusEnum,\n        'Execution with ID \"mock-execution-id\" has an unexpected status of \"unknown\".',\n      ],\n    ])(\n      'Throws if the execution %s',\n      async (description: string, status: FlowsGetExecutionOutputsStatusEnum, expectedError: string) => {\n        const aiId = 'mock-ai-id';\n        const executionId = 'mock-execution-id';\n        const command = 'processChatMessage';\n        const inputs = { query: 'space facts' };\n\n        jest.spyOn(client.chatbotExecution, 'execute').mockResolvedValue({ executionId });\n        jest.spyOn(client.chatbotExecution, 'getExecutionOutput').mockResolvedValueOnce({\n          status,\n          outputs: {},\n          finishedAt: 'mock-finished-at',\n          startedAt: 'mock-started-at',\n        });\n\n        await expect(commandExecutor.execute(aiId, command, inputs)).rejects.toThrow(expectedError);\n      },\n    );\n\n    it('Throws if fetching the execution outputs fails', async () => {\n      const aiId = 'mock-ai-id';\n      const executionId = 'mock-execution-id';\n      const command = 'processChatMessage';\n      const inputs = { query: 'space facts' };\n      const error = new Error('Failed to fetch execution outputs.');\n\n      jest.spyOn(client.chatbotExecution, 'execute').mockResolvedValue({ executionId });\n      jest.spyOn(client.chatbotExecution, 'getExecutionOutput').mockRejectedValue(error);\n\n      await expect(commandExecutor.execute(aiId, command, inputs)).rejects.toThrow(error);\n    });\n  });\n});\n"]}

@@ -82,3 +82,13 @@ "use strict";

});
it('Throws if fetching the execution outputs fails', async () => {
const aiId = 'mock-ai-id';
const executionId = 'mock-execution-id';
const command = 'processMessage';
const inputs = { Query: 'space facts' };
const error = new Error('Failed to fetch execution outputs.');
jest.spyOn(client.generative, 'execute').mockResolvedValue({ executionId });
jest.spyOn(client.generative, 'getExecutionOutput').mockRejectedValue(error);
await expect(commandExecutor.execute(aiId, command, inputs)).rejects.toThrow(error);
});
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"GenerativeCommandExecutor.spec.js","sourceRoot":"","sources":["../../../src/utils/CommandExecutor/GenerativeCommandExecutor.spec.ts"],"names":[],"mappings":"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","sourcesContent":["import { Api, FlowsGetExecutionOutputsStatusEnum, HttpClient } from '../../generated/DxpAiService';\nimport { GenerativeCommandExecutor } from './GenerativeCommandExecutor';\n\ndescribe('GenerativeCommandExecutor', () => {\n  let client: Api<unknown>;\n  let commandExecutor: GenerativeCommandExecutor;\n\n  beforeEach(() => {\n    client = new Api({} as HttpClient);\n    commandExecutor = new GenerativeCommandExecutor(client);\n\n    jest.spyOn(global, 'setTimeout').mockImplementation((callback) => {\n      callback();\n      // eslint-disable-next-line\n      return 0 as any;\n    });\n  });\n\n  describe('.execute()', () => {\n    it('Resolves with the outputs of the execution', async () => {\n      const aiId = 'mock-ai-id';\n      const executionId = 'mock-execution-id';\n      const command = 'processMessage';\n      const inputs = { Query: 'space facts', IsPreview: false };\n      const outputs = { Message: 'transformed space facts' };\n\n      jest.spyOn(client.generative, 'execute').mockResolvedValue({ executionId });\n      jest\n        .spyOn(client.generative, 'getExecutionOutput')\n        .mockResolvedValueOnce({\n          status: 'pending',\n          outputs: {},\n          finishedAt: null,\n          startedAt: null,\n        })\n        .mockResolvedValueOnce({\n          status: 'executing',\n          outputs: {},\n          finishedAt: null,\n          startedAt: 'mock-started-at',\n        })\n        .mockResolvedValueOnce({\n          status: 'succeeded',\n          outputs,\n          finishedAt: 'mock-finished-at',\n          startedAt: 'mock-started-at',\n        });\n\n      const result = await commandExecutor.execute(aiId, command, inputs);\n\n      expect(result).toEqual({\n        status: 'succeeded',\n        outputs,\n        finishedAt: 'mock-finished-at',\n        startedAt: 'mock-started-at',\n      });\n      expect(client.generative.execute).toHaveBeenCalledWith(aiId, command, { inputs });\n      expect(client.generative.getExecutionOutput).toHaveBeenCalledTimes(3);\n      expect(client.generative.getExecutionOutput).toHaveBeenCalledWith(aiId, command, executionId);\n    });\n\n    it.each([\n      ['fails', 'failed' as FlowsGetExecutionOutputsStatusEnum, 'Execution with ID \"mock-execution-id\" failed.'],\n      [\n        'is cancelled',\n        'cancelled' as FlowsGetExecutionOutputsStatusEnum,\n        'Execution with ID \"mock-execution-id\" was cancelled.',\n      ],\n      [\n        'has an unknown status',\n        'unknown' as FlowsGetExecutionOutputsStatusEnum,\n        'Execution with ID \"mock-execution-id\" has an unexpected status of \"unknown\".',\n      ],\n    ])(\n      'Throws if the execution %s',\n      async (description: string, status: FlowsGetExecutionOutputsStatusEnum, expectedError: string) => {\n        const aiId = 'mock-ai-id';\n        const executionId = 'mock-execution-id';\n        const command = 'processMessage';\n        const inputs = { Query: 'space facts', IsPreview: false };\n\n        jest.spyOn(client.generative, 'execute').mockResolvedValue({ executionId });\n        jest.spyOn(client.generative, 'getExecutionOutput').mockResolvedValueOnce({\n          status,\n          outputs: {},\n          finishedAt: 'mock-finished-at',\n          startedAt: 'mock-started-at',\n        });\n\n        await expect(commandExecutor.execute(aiId, command, inputs)).rejects.toThrow(expectedError);\n      },\n    );\n  });\n});\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"GenerativeCommandExecutor.spec.js","sourceRoot":"","sources":["../../../src/utils/CommandExecutor/GenerativeCommandExecutor.spec.ts"],"names":[],"mappings":"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","sourcesContent":["import { Api, FlowsGetExecutionOutputsStatusEnum, HttpClient } from '../../generated/DxpAiService';\nimport { GenerativeCommandExecutor } from './GenerativeCommandExecutor';\n\ndescribe('GenerativeCommandExecutor', () => {\n  let client: Api<unknown>;\n  let commandExecutor: GenerativeCommandExecutor;\n\n  beforeEach(() => {\n    client = new Api({} as HttpClient);\n    commandExecutor = new GenerativeCommandExecutor(client);\n\n    jest.spyOn(global, 'setTimeout').mockImplementation((callback) => {\n      callback();\n      // eslint-disable-next-line\n      return 0 as any;\n    });\n  });\n\n  describe('.execute()', () => {\n    it('Resolves with the outputs of the execution', async () => {\n      const aiId = 'mock-ai-id';\n      const executionId = 'mock-execution-id';\n      const command = 'processMessage';\n      const inputs = { Query: 'space facts', IsPreview: false };\n      const outputs = { Message: 'transformed space facts' };\n\n      jest.spyOn(client.generative, 'execute').mockResolvedValue({ executionId });\n      jest\n        .spyOn(client.generative, 'getExecutionOutput')\n        .mockResolvedValueOnce({\n          status: 'pending',\n          outputs: {},\n          finishedAt: null,\n          startedAt: null,\n        })\n        .mockResolvedValueOnce({\n          status: 'executing',\n          outputs: {},\n          finishedAt: null,\n          startedAt: 'mock-started-at',\n        })\n        .mockResolvedValueOnce({\n          status: 'succeeded',\n          outputs,\n          finishedAt: 'mock-finished-at',\n          startedAt: 'mock-started-at',\n        });\n\n      const result = await commandExecutor.execute(aiId, command, inputs);\n\n      expect(result).toEqual({\n        status: 'succeeded',\n        outputs,\n        finishedAt: 'mock-finished-at',\n        startedAt: 'mock-started-at',\n      });\n      expect(client.generative.execute).toHaveBeenCalledWith(aiId, command, { inputs });\n      expect(client.generative.getExecutionOutput).toHaveBeenCalledTimes(3);\n      expect(client.generative.getExecutionOutput).toHaveBeenCalledWith(aiId, command, executionId);\n    });\n\n    it.each([\n      ['fails', 'failed' as FlowsGetExecutionOutputsStatusEnum, 'Execution with ID \"mock-execution-id\" failed.'],\n      [\n        'is cancelled',\n        'cancelled' as FlowsGetExecutionOutputsStatusEnum,\n        'Execution with ID \"mock-execution-id\" was cancelled.',\n      ],\n      [\n        'has an unknown status',\n        'unknown' as FlowsGetExecutionOutputsStatusEnum,\n        'Execution with ID \"mock-execution-id\" has an unexpected status of \"unknown\".',\n      ],\n    ])(\n      'Throws if the execution %s',\n      async (description: string, status: FlowsGetExecutionOutputsStatusEnum, expectedError: string) => {\n        const aiId = 'mock-ai-id';\n        const executionId = 'mock-execution-id';\n        const command = 'processMessage';\n        const inputs = { Query: 'space facts', IsPreview: false };\n\n        jest.spyOn(client.generative, 'execute').mockResolvedValue({ executionId });\n        jest.spyOn(client.generative, 'getExecutionOutput').mockResolvedValueOnce({\n          status,\n          outputs: {},\n          finishedAt: 'mock-finished-at',\n          startedAt: 'mock-started-at',\n        });\n\n        await expect(commandExecutor.execute(aiId, command, inputs)).rejects.toThrow(expectedError);\n      },\n    );\n  });\n\n  it('Throws if fetching the execution outputs fails', async () => {\n    const aiId = 'mock-ai-id';\n    const executionId = 'mock-execution-id';\n    const command = 'processMessage';\n    const inputs = { Query: 'space facts' };\n    const error = new Error('Failed to fetch execution outputs.');\n\n    jest.spyOn(client.generative, 'execute').mockResolvedValue({ executionId });\n    jest.spyOn(client.generative, 'getExecutionOutput').mockRejectedValue(error);\n\n    await expect(commandExecutor.execute(aiId, command, inputs)).rejects.toThrow(error);\n  });\n});\n"]}

2

package.json

@@ -5,3 +5,3 @@ {

"private": false,
"version": "0.20.0",
"version": "0.20.1",
"description": "Exposes the DXP AI service as a package for consumers",

@@ -8,0 +8,0 @@ "main": "dist/index.js",

@@ -20,4 +20,11 @@ import { Api, ExecutionOutputsResponse } from '../../generated/DxpAiService';

setTimeout(async () => {
const result = await fetch();
let result: T;
try {
result = await fetch();
} catch (error: unknown) {
reject(error);
return;
}
switch (result.status) {

@@ -24,0 +31,0 @@ case 'executing':

@@ -93,3 +93,16 @@ import { Api, FlowsGetExecutionOutputsStatusEnum, HttpClient } from '../../generated/DxpAiService';

);
it('Throws if fetching the execution outputs fails', async () => {
const aiId = 'mock-ai-id';
const executionId = 'mock-execution-id';
const command = 'processChatMessage';
const inputs = { query: 'space facts' };
const error = new Error('Failed to fetch execution outputs.');
jest.spyOn(client.chatbotExecution, 'execute').mockResolvedValue({ executionId });
jest.spyOn(client.chatbotExecution, 'getExecutionOutput').mockRejectedValue(error);
await expect(commandExecutor.execute(aiId, command, inputs)).rejects.toThrow(error);
});
});
});

@@ -94,2 +94,15 @@ import { Api, FlowsGetExecutionOutputsStatusEnum, HttpClient } from '../../generated/DxpAiService';

});
it('Throws if fetching the execution outputs fails', async () => {
const aiId = 'mock-ai-id';
const executionId = 'mock-execution-id';
const command = 'processMessage';
const inputs = { Query: 'space facts' };
const error = new Error('Failed to fetch execution outputs.');
jest.spyOn(client.generative, 'execute').mockResolvedValue({ executionId });
jest.spyOn(client.generative, 'getExecutionOutput').mockRejectedValue(error);
await expect(commandExecutor.execute(aiId, command, inputs)).rejects.toThrow(error);
});
});

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc