mirror of
https://github.com/n8n-io/n8n.git
synced 2025-01-11 12:57:29 -08:00
fix(core): Allow license:clear command to be used for licenses that failed renewal (#10665)
Co-authored-by: कारतोफ्फेलस्क्रिप्ट™ <netroy@users.noreply.github.com>
This commit is contained in:
parent
3ea114129b
commit
a422c5ac7b
|
@ -12,10 +12,14 @@ export class ClearLicenseCommand extends BaseCommand {
|
|||
async run() {
|
||||
this.logger.info('Clearing license from database.');
|
||||
|
||||
// Invoke shutdown() to force any floating entitlements to be released
|
||||
// Attempt to invoke shutdown() to force any floating entitlements to be released
|
||||
const license = Container.get(License);
|
||||
await license.init();
|
||||
try {
|
||||
await license.shutdown();
|
||||
} catch {
|
||||
this.logger.info('License shutdown failed. Continuing with clearing license from database.');
|
||||
}
|
||||
|
||||
await Container.get(SettingsRepository).delete({
|
||||
key: SETTINGS_LICENSE_CERT_KEY,
|
||||
|
|
|
@ -1,10 +1,14 @@
|
|||
import { License } from '@/license';
|
||||
import { LoadNodesAndCredentials } from '@/load-nodes-and-credentials';
|
||||
import { ClearLicenseCommand } from '@/commands/license/clear';
|
||||
import { Container } from 'typedi';
|
||||
|
||||
import { setupTestCommand } from '@test-integration/utils/test-command';
|
||||
import { mockInstance } from '../../shared/mocking';
|
||||
|
||||
import { ClearLicenseCommand } from '@/commands/license/clear';
|
||||
import { SETTINGS_LICENSE_CERT_KEY } from '@/constants';
|
||||
import { SettingsRepository } from '@/databases/repositories/settings.repository';
|
||||
import { License } from '@/license';
|
||||
import { LoadNodesAndCredentials } from '@/load-nodes-and-credentials';
|
||||
|
||||
mockInstance(LoadNodesAndCredentials);
|
||||
const license = mockInstance(License);
|
||||
const command = setupTestCommand(ClearLicenseCommand);
|
||||
|
@ -15,3 +19,17 @@ test('license:clear invokes shutdown() to release any floating entitlements', as
|
|||
expect(license.init).toHaveBeenCalledTimes(1);
|
||||
expect(license.shutdown).toHaveBeenCalledTimes(1);
|
||||
});
|
||||
|
||||
test('license:clear deletes the license from the DB even if shutdown() fails', async () => {
|
||||
license.shutdown.mockRejectedValueOnce(new Error('shutdown failed'));
|
||||
|
||||
const settingsRepository = Container.get(SettingsRepository);
|
||||
|
||||
settingsRepository.delete = jest.fn();
|
||||
|
||||
await command.run();
|
||||
|
||||
expect(settingsRepository.delete).toHaveBeenCalledWith({
|
||||
key: SETTINGS_LICENSE_CERT_KEY,
|
||||
});
|
||||
});
|
||||
|
|
Loading…
Reference in a new issue