diff --git a/src/pybind/mgr/dashboard/frontend/cypress/integration/cluster/services.po.ts b/src/pybind/mgr/dashboard/frontend/cypress/integration/cluster/services.po.ts index e4f4561e820..cbc900813dc 100644 --- a/src/pybind/mgr/dashboard/frontend/cypress/integration/cluster/services.po.ts +++ b/src/pybind/mgr/dashboard/frontend/cypress/integration/cluster/services.po.ts @@ -37,7 +37,13 @@ export class ServicesPageHelper extends PageHelper { }); } - addService(serviceType: string, exist?: boolean, count = '1', snmpVersion?: string) { + addService( + serviceType: string, + exist?: boolean, + count = '1', + snmpVersion?: string, + snmpPrivProtocol?: boolean + ) { cy.get(`${this.pages.create.id}`).within(() => { this.selectServiceType(serviceType); switch (serviceType) { @@ -67,12 +73,14 @@ export class ServicesPageHelper extends PageHelper { } else { cy.get('#engine_id').type('800C53F00000'); this.selectOption('auth_protocol', 'SHA'); - this.selectOption('privacy_protocol', 'DES'); + if (snmpPrivProtocol) { + this.selectOption('privacy_protocol', 'DES'); + cy.get('#snmp_v3_priv_password').type('testencrypt'); + } // Credentials cy.get('#snmp_v3_auth_username').type('test'); cy.get('#snmp_v3_auth_password').type('testpass'); - cy.get('#snmp_v3_priv_password').type('testencrypt'); } break; diff --git a/src/pybind/mgr/dashboard/frontend/cypress/integration/orchestrator/workflow/09-services.e2e-spec.ts b/src/pybind/mgr/dashboard/frontend/cypress/integration/orchestrator/workflow/09-services.e2e-spec.ts index c5fd7cb9733..c266c81b712 100644 --- a/src/pybind/mgr/dashboard/frontend/cypress/integration/orchestrator/workflow/09-services.e2e-spec.ts +++ b/src/pybind/mgr/dashboard/frontend/cypress/integration/orchestrator/workflow/09-services.e2e-spec.ts @@ -77,7 +77,20 @@ describe('Services page', () => { it('should create and delete snmp-gateway service with version V3', () => { services.navigateTo('create'); - services.addService('snmp-gateway', false, '1', 'V3'); + services.addService('snmp-gateway', false, '1', 'V3', true); + services.checkExist('snmp-gateway', true); + + services.clickServiceTab('snmp-gateway', 'Details'); + cy.get('cd-service-details').within(() => { + services.checkServiceStatus('snmp-gateway'); + }); + + services.deleteService('snmp-gateway'); + }); + + it('should create and delete snmp-gateway service with version V3 and w/o privacy protocol', () => { + services.navigateTo('create'); + services.addService('snmp-gateway', false, '1', 'V3', false); services.checkExist('snmp-gateway', true); services.clickServiceTab('snmp-gateway', 'Details'); diff --git a/src/pybind/mgr/dashboard/frontend/src/app/ceph/cluster/services/service-form/service-form.component.html b/src/pybind/mgr/dashboard/frontend/src/app/ceph/cluster/services/service-form/service-form.component.html index e1e8317e9bf..24dac8871f7 100644 --- a/src/pybind/mgr/dashboard/frontend/src/app/ceph/cluster/services/service-form/service-form.component.html +++ b/src/pybind/mgr/dashboard/frontend/src/app/ceph/cluster/services/service-form/service-form.component.html @@ -63,7 +63,8 @@ </div> <!-- Service id --> - <div class="form-group row"> + <div class="form-group row" + *ngIf="serviceForm.controls.service_type.value !== 'snmp-gateway'"> <label i18n class="cd-col-form-label" [ngClass]="{'required': ['mds', 'rgw', 'nfs', 'iscsi', 'ingress'].includes(serviceForm.controls.service_type.value)}" diff --git a/src/pybind/mgr/dashboard/frontend/src/app/ceph/cluster/services/service-form/service-form.component.ts b/src/pybind/mgr/dashboard/frontend/src/app/ceph/cluster/services/service-form/service-form.component.ts index 06fe53bae05..d45d939d587 100644 --- a/src/pybind/mgr/dashboard/frontend/src/app/ceph/cluster/services/service-form/service-form.component.ts +++ b/src/pybind/mgr/dashboard/frontend/src/app/ceph/cluster/services/service-form/service-form.component.ts @@ -245,7 +245,7 @@ export class ServiceFormComponent extends CdForm implements OnInit { null, [ CdValidators.requiredIf({ - service_type: 'snmp-gateway', + snmp_version: 'V3', unmanaged: false }) ] @@ -254,25 +254,17 @@ export class ServiceFormComponent extends CdForm implements OnInit { 'SHA', [ CdValidators.requiredIf({ - service_type: 'snmp-gateway', - unmanaged: false - }) - ] - ], - privacy_protocol: [ - null, - [ - CdValidators.requiredIf({ - service_type: 'snmp-gateway', + snmp_version: 'V3', unmanaged: false }) ] ], + privacy_protocol: [null], snmp_community: [ null, [ CdValidators.requiredIf({ - service_type: 'snmp-gateway', + snmp_version: 'V2c', unmanaged: false }) ] @@ -281,7 +273,7 @@ export class ServiceFormComponent extends CdForm implements OnInit { null, [ CdValidators.requiredIf({ - service_type: 'snmp-gateway', + snmp_version: 'V3', unmanaged: false }) ] @@ -290,7 +282,7 @@ export class ServiceFormComponent extends CdForm implements OnInit { null, [ CdValidators.requiredIf({ - service_type: 'snmp-gateway', + snmp_version: 'V3', unmanaged: false }) ] @@ -299,7 +291,7 @@ export class ServiceFormComponent extends CdForm implements OnInit { null, [ CdValidators.requiredIf({ - service_type: 'snmp-gateway', + privacy_protocol: { op: '!empty' }, unmanaged: false }) ]