Commit 0d801ac4 authored by David O'Regan's avatar David O'Regan

Merge branch 'oncall-schedule-timeline-6-shift-item-specs' into 'master'

Update On-call test suite

See merge request gitlab-org/gitlab!58436
parents 080fac7d d102a1bb
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe 'On-call Schedules', :js do
let_it_be(:user) { create(:user) }
let_it_be(:group) { create(:group) }
let_it_be_with_reload(:project) { create(:project) }
before do
stub_licensed_features(oncall_schedules: true)
stub_feature_flags(multiple_oncall_schedules: true)
project.add_maintainer(user)
sign_in(user)
visit project_incident_management_oncall_schedules_path(project)
wait_for_all_requests
end
context 'displaying the empty state by default' do
it { expect(page).to have_button 'Add a schedule' }
end
context 'creating a schedule' do
it 'adds a schedule given valid options' do
click_button 'Add a schedule'
fill_in 'schedule-name', with: 'Test schedule'
fill_in 'schedule-description', with: 'Test schedule description'
click_button 'Select timezone'
click_button '(UTC -12:00) -12 International Date Line West'
click_button 'Add schedule'
wait_for_all_requests
expect(page).to have_css '.gl-alert-tip'
expect(page).to have_css '.gl-card'
expect(page).to have_text 'Test schedule'
expect(page).to have_text 'Test schedule description | (UTC -12:00) Etc/GMT+12'
end
end
end
...@@ -207,6 +207,18 @@ describe('On-call schedule', () => { ...@@ -207,6 +207,18 @@ describe('On-call schedule', () => {
expect(dateTimeUtility.nWeeksBefore).toHaveBeenCalledWith(expect.any(Date), 2); expect(dateTimeUtility.nWeeksBefore).toHaveBeenCalledWith(expect.any(Date), 2);
expect(wrapper.vm.timeframeStartDate).toEqual(mockDate); expect(wrapper.vm.timeframeStartDate).toEqual(mockDate);
}); });
it('should query with a two week timeframe', () => {
const expectedVariables = {
iids: [mockSchedule.iid],
projectPath: 'group/project',
startsAt: new Date('2020-07-06'),
endsAt: new Date('2020-07-20'),
};
expect(wrapper.vm.$options.apollo.rotations.variables.bind(wrapper.vm)()).toEqual(
expectedVariables,
);
});
}); });
describe('DAYS view', () => { describe('DAYS view', () => {
...@@ -228,6 +240,18 @@ describe('On-call schedule', () => { ...@@ -228,6 +240,18 @@ describe('On-call schedule', () => {
expect(dateTimeUtility.nDaysBefore).toHaveBeenCalledWith(expect.any(Date), 1); expect(dateTimeUtility.nDaysBefore).toHaveBeenCalledWith(expect.any(Date), 1);
expect(wrapper.vm.timeframeStartDate).toEqual(mockDate); expect(wrapper.vm.timeframeStartDate).toEqual(mockDate);
}); });
it('should query with a two week timeframe', () => {
const expectedVariables = {
iids: [mockSchedule.iid],
projectPath: 'group/project',
startsAt: new Date('2020-07-06'),
endsAt: new Date('2020-07-07'),
};
expect(wrapper.vm.$options.apollo.rotations.variables.bind(wrapper.vm)()).toEqual(
expectedVariables,
);
});
}); });
}); });
......
...@@ -12,12 +12,12 @@ const shift = { ...@@ -12,12 +12,12 @@ const shift = {
}, },
}, },
// 3.5 days // 3.5 days
startsAt: '2021-01-12T10:04:56.333Z', startsAt: '2021-01-15T04:00:00.000Z',
endsAt: '2021-01-15T22:04:56.333Z', endsAt: '2021-01-15T06:00:00.000Z', // absolute shift length is 2 hours(7200000 milliseconds)
}; };
const CELL_WIDTH = 50; const CELL_WIDTH = 50;
const timeframeItem = new Date(2021, 0, 13); const timeframeItem = new Date(2021, 0, 13); // Timeframe starts on the 13th
const timeframe = [timeframeItem, new Date(nDaysAfter(timeframeItem, DAYS_IN_WEEK))]; const timeframe = [timeframeItem, new Date(nDaysAfter(timeframeItem, DAYS_IN_WEEK))];
describe('ee/oncall_schedules/components/schedule/components/shifts/components/shift_item.vue', () => { describe('ee/oncall_schedules/components/schedule/components/shifts/components/shift_item.vue', () => {
...@@ -28,8 +28,8 @@ describe('ee/oncall_schedules/components/schedule/components/shifts/components/s ...@@ -28,8 +28,8 @@ describe('ee/oncall_schedules/components/schedule/components/shifts/components/s
propsData: { propsData: {
shift, shift,
timeframe, timeframe,
presetType: PRESET_TYPES.WEEKS, presetType: PRESET_TYPES.WEEKS, // Total grid time in MS: 1209600000
timelineWidth: CELL_WIDTH * 14, timelineWidth: CELL_WIDTH * 14, // Total grid width in px: 700
...props, ...props,
}, },
}); });
...@@ -45,42 +45,28 @@ describe('ee/oncall_schedules/components/schedule/components/shifts/components/s ...@@ -45,42 +45,28 @@ describe('ee/oncall_schedules/components/schedule/components/shifts/components/s
const findRotationAssignee = () => wrapper.findComponent(RotationsAssignee); const findRotationAssignee = () => wrapper.findComponent(RotationsAssignee);
describe('shift overlaps inside the current time-frame with a shift greater than 24 hours', () => { it('should render a rotation assignee child component', () => {
it('should render a rotation assignee child component', () => { expect(findRotationAssignee().exists()).toBe(true);
expect(findRotationAssignee().exists()).toBe(true);
});
}); });
describe('shift overlaps inside the current time-frame with a shift equal to 24 hours', () => { it('should calculate a rotation assignee child components width based on its absolute time', () => {
beforeEach(() => { // See `getPixelWidth`
createComponent({ // const width = ((durationMillis + DLSOffset) * timelineWidth) / totalTime;
props: { shift: { ...shift, startsAt: '2021-01-14T10:04:56.333Z' } }, // ((7200000 + 0) * 700) / 1209600000
data: { shiftTimeUnitWidth: CELL_WIDTH }, expect(findRotationAssignee().props('rotationAssigneeStyle').width).toBe('4px');
});
});
it('should render a rotation assignee child component', () => {
expect(findRotationAssignee().exists()).toBe(true);
});
}); });
describe('shift overlaps inside the current time-frame with a shift less than 24 hours', () => { it('should calculate a shift width the same as rotation assignee child components width', () => {
beforeEach(() => { expect(findRotationAssignee().props('shiftWidth')).toBe(4);
createComponent({ });
props: {
shift: {
...shift,
startsAt: '2021-01-14T10:04:56.333Z',
endsAt: '2021-01-14T12:04:56.333Z',
},
rotationLength: { lengthUnit: 'HOURS' },
},
data: { shiftTimeUnitWidth: CELL_WIDTH },
});
});
it('should render a rotation assignee child component', () => { it('should a rotation assignee child components offset based on its absolute time', () => {
expect(findRotationAssignee().exists()).toBe(true); // See `getPixelOffset`
}); // const left = (timelineWidth * timeOffset) / totalTime;
// (700 * 187200000) / 1209600000
const rotationAssigneeOffset = parseFloat(
findRotationAssignee().props('rotationAssigneeStyle').left,
);
expect(rotationAssigneeOffset).toBeCloseTo(108.33);
}); });
}); });
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment