diff options
Diffstat (limited to 'src/pybind/mgr/dashboard/frontend/src/app/ceph/cluster/logs/logs.component.spec.ts')
-rw-r--r-- | src/pybind/mgr/dashboard/frontend/src/app/ceph/cluster/logs/logs.component.spec.ts | 169 |
1 files changed, 169 insertions, 0 deletions
diff --git a/src/pybind/mgr/dashboard/frontend/src/app/ceph/cluster/logs/logs.component.spec.ts b/src/pybind/mgr/dashboard/frontend/src/app/ceph/cluster/logs/logs.component.spec.ts new file mode 100644 index 000000000..69c6051d2 --- /dev/null +++ b/src/pybind/mgr/dashboard/frontend/src/app/ceph/cluster/logs/logs.component.spec.ts @@ -0,0 +1,169 @@ +import { HttpClientTestingModule } from '@angular/common/http/testing'; +import { ComponentFixture, TestBed } from '@angular/core/testing'; +import { FormsModule } from '@angular/forms'; + +import { NgbDatepickerModule, NgbNavModule, NgbTimepickerModule } from '@ng-bootstrap/ng-bootstrap'; +import { ToastrModule } from 'ngx-toastr'; +import { of } from 'rxjs'; + +import { LogsService } from '~/app/shared/api/logs.service'; +import { SharedModule } from '~/app/shared/shared.module'; +import { configureTestBed } from '~/testing/unit-test-helper'; +import { LogsComponent } from './logs.component'; + +describe('LogsComponent', () => { + let component: LogsComponent; + let fixture: ComponentFixture<LogsComponent>; + let logsService: LogsService; + let logsServiceSpy: jasmine.Spy; + + configureTestBed({ + imports: [ + HttpClientTestingModule, + NgbNavModule, + SharedModule, + FormsModule, + NgbDatepickerModule, + NgbTimepickerModule, + ToastrModule.forRoot() + ], + declarations: [LogsComponent] + }); + + beforeEach(() => { + logsService = TestBed.inject(LogsService); + logsServiceSpy = spyOn(logsService, 'getLogs'); + logsServiceSpy.and.returnValue(of(null)); + fixture = TestBed.createComponent(LogsComponent); + component = fixture.componentInstance; + }); + + it('should create', () => { + expect(component).toBeTruthy(); + }); + + describe('abstractFilters', () => { + it('after initialized', () => { + const filters = component.abstractFilters(); + expect(filters.priority).toBe('All'); + expect(filters.key).toBe(''); + expect(filters.yearMonthDay).toBe(''); + expect(filters.sTime).toBe(0); + expect(filters.eTime).toBe(1439); + }); + it('change date', () => { + component.selectedDate = { year: 2019, month: 1, day: 1 }; + component.startTime = { hour: 1, minute: 10 }; + component.endTime = { hour: 12, minute: 10 }; + const filters = component.abstractFilters(); + expect(filters.yearMonthDay).toBe('2019-01-01'); + expect(filters.sTime).toBe(70); + expect(filters.eTime).toBe(730); + }); + }); + + describe('filterLogs', () => { + const contentData: Record<string, any> = { + clog: [ + { + name: 'priority', + stamp: '2019-02-21 09:39:49.572801', + message: 'Manager daemon localhost is now available', + priority: '[ERR]' + }, + { + name: 'search', + stamp: '2019-02-21 09:39:49.572801', + message: 'Activating manager daemon localhost', + priority: '[INF]' + }, + { + name: 'date', + stamp: '2019-01-21 09:39:49.572801', + message: 'Manager daemon localhost is now available', + priority: '[INF]' + }, + { + name: 'time', + stamp: '2019-02-21 01:39:49.572801', + message: 'Manager daemon localhost is now available', + priority: '[INF]' + } + ], + audit_log: [] + }; + const resetFilter = () => { + component.selectedDate = null; + component.priority = 'All'; + component.search = ''; + component.startTime = { hour: 0, minute: 0 }; + component.endTime = { hour: 23, minute: 59 }; + }; + beforeEach(() => { + component.contentData = contentData; + }); + + it('show all log', () => { + component.filterLogs(); + expect(component.clog.length).toBe(4); + }); + + it('filter by search key', () => { + resetFilter(); + component.search = 'Activating'; + component.filterLogs(); + expect(component.clog.length).toBe(1); + expect(component.clog[0].name).toBe('search'); + }); + + it('filter by date', () => { + resetFilter(); + component.selectedDate = { year: 2019, month: 1, day: 21 }; + component.filterLogs(); + expect(component.clog.length).toBe(1); + expect(component.clog[0].name).toBe('date'); + }); + + it('filter by priority', () => { + resetFilter(); + component.priority = '[ERR]'; + component.filterLogs(); + expect(component.clog.length).toBe(1); + expect(component.clog[0].name).toBe('priority'); + }); + + it('filter by time range', () => { + resetFilter(); + component.startTime = { hour: 1, minute: 0 }; + component.endTime = { hour: 2, minute: 0 }; + component.filterLogs(); + expect(component.clog.length).toBe(1); + expect(component.clog[0].name).toBe('time'); + }); + }); + + describe('convert logs to text', () => { + it('convert cluster & audit logs to text', () => { + const logsPayload = { + clog: [ + { + name: 'priority', + stamp: '2019-02-21 09:39:49.572801', + message: 'Manager daemon localhost is now available', + priority: '[ERR]' + } + ], + audit_log: [ + { + stamp: '2020-12-22T11:18:13.896920+0000', + priority: '[INF]' + } + ] + }; + logsServiceSpy.and.returnValue(of(logsPayload)); + fixture.detectChanges(); + expect(component.clogText).toContain(logsPayload.clog[0].message); + expect(component.auditLogText).toContain(logsPayload.audit_log[0].priority); + }); + }); +}); |