From 09e12a0626c70dc5d4cfc2920f89b71af1966983 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Zolt=C3=A1n=20Bedi?= Date: Thu, 13 Jun 2024 16:38:31 +0200 Subject: [PATCH] Fix: Problems panel failing for versions before 7.0.0 (#1840) * Fix: Problems panel failing for versions before 7.0.0 * Add tests * Use spy instead of new argument --- .../zabbix_api/zabbixAPIConnector.test.ts | 27 +++++++++++++++++++ .../zabbix_api/zabbixAPIConnector.ts | 11 ++++---- 2 files changed, 33 insertions(+), 5 deletions(-) create mode 100644 src/datasource/zabbix/connectors/zabbix_api/zabbixAPIConnector.test.ts diff --git a/src/datasource/zabbix/connectors/zabbix_api/zabbixAPIConnector.test.ts b/src/datasource/zabbix/connectors/zabbix_api/zabbixAPIConnector.test.ts new file mode 100644 index 00000000..d2ff32ea --- /dev/null +++ b/src/datasource/zabbix/connectors/zabbix_api/zabbixAPIConnector.test.ts @@ -0,0 +1,27 @@ +import { ZabbixAPIConnector } from './zabbixAPIConnector'; + +describe('Zabbix API connector', () => { + describe('getProxies function', () => { + beforeAll(() => { + jest.spyOn(ZabbixAPIConnector.prototype, 'initVersion').mockResolvedValue(''); + }); + + it('should send the name parameter to the request when version is 7 or greater for the getProxies', async () => { + const zabbixAPIConnector = new ZabbixAPIConnector(true, true, 123); + zabbixAPIConnector.version = '7.0.0'; + zabbixAPIConnector.request = jest.fn(); + + await zabbixAPIConnector.getProxies(); + expect(zabbixAPIConnector.request).toHaveBeenCalledWith('proxy.get', { output: ['proxyid', 'name'] }); + }); + + it('should send the host parameter when version is less than 7.0.0', () => { + const zabbixAPIConnector = new ZabbixAPIConnector(true, true, 123); + zabbixAPIConnector.version = '6.0.0'; + zabbixAPIConnector.request = jest.fn(); + + zabbixAPIConnector.getProxies(); + expect(zabbixAPIConnector.request).toHaveBeenCalledWith('proxy.get', { output: ['proxyid', 'host'] }); + }); + }); +}); diff --git a/src/datasource/zabbix/connectors/zabbix_api/zabbixAPIConnector.ts b/src/datasource/zabbix/connectors/zabbix_api/zabbixAPIConnector.ts index 89ef2200..845e08a4 100644 --- a/src/datasource/zabbix/connectors/zabbix_api/zabbixAPIConnector.ts +++ b/src/datasource/zabbix/connectors/zabbix_api/zabbixAPIConnector.ts @@ -548,7 +548,7 @@ export class ZabbixAPIConnector { }; // Before version 7.0.0 proxy_hostid was used, after - proxyid - if (semver.lte(this.version, '7.0.0')) { + if (semver.lt(this.version, '7.0.0')) { params.selectHosts.push('proxy_hostid'); } else { params.selectHosts.push('proxyid'); @@ -582,7 +582,7 @@ export class ZabbixAPIConnector { }; // Before version 7.0.0 proxy_hostid was used, after - proxyid - if (semver.lte(this.version, '7.0.0')) { + if (semver.lt(this.version, '7.0.0')) { params.selectHosts.push('proxy_hostid'); } else { params.selectHosts.push('proxyid'); @@ -877,10 +877,11 @@ export class ZabbixAPIConnector { const params = { output: ['proxyid'], }; - if (semver.lte(this.version, '7.0.0')) { - params.output.push('name'); - } else { + // Before version 7.0.0 host was used, after - name + if (semver.lt(this.version, '7.0.0')) { params.output.push('host'); + } else { + params.output.push('name'); } return this.request('proxy.get', params);