2022-09-10 00:31:03 +00:00
|
|
|
/*****************************************************************************
|
|
|
|
* Open MCT, Copyright (c) 2014-2023, United States Government
|
|
|
|
* as represented by the Administrator of the National Aeronautics and Space
|
|
|
|
* Administration. All rights reserved.
|
|
|
|
*
|
|
|
|
* Open MCT is licensed under the Apache License, Version 2.0 (the
|
|
|
|
* "License"); you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0.
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
|
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
|
|
* License for the specific language governing permissions and limitations
|
|
|
|
* under the License.
|
|
|
|
*
|
|
|
|
* Open MCT includes source code licensed under additional open source
|
|
|
|
* licenses. See the Open Source Licenses file (LICENSES.md) included with
|
|
|
|
* this source code distribution or the Licensing information page available
|
|
|
|
* at runtime from the About dialog for additional information.
|
|
|
|
*****************************************************************************/
|
|
|
|
|
|
|
|
const { test, expect } = require('../../../pluginFixtures');
|
|
|
|
const { createDomainObjectWithDefaults, createPlanFromJSON } = require('../../../appActions');
|
|
|
|
|
|
|
|
const testPlan = {
|
|
|
|
TEST_GROUP: [
|
|
|
|
{
|
|
|
|
name: 'Past event 1',
|
|
|
|
start: 1660320408000,
|
|
|
|
end: 1660343797000,
|
|
|
|
type: 'TEST-GROUP',
|
|
|
|
color: 'orange',
|
|
|
|
textColor: 'white'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: 'Past event 2',
|
|
|
|
start: 1660406808000,
|
|
|
|
end: 1660429160000,
|
|
|
|
type: 'TEST-GROUP',
|
|
|
|
color: 'orange',
|
|
|
|
textColor: 'white'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: 'Past event 3',
|
|
|
|
start: 1660493208000,
|
|
|
|
end: 1660503981000,
|
|
|
|
type: 'TEST-GROUP',
|
|
|
|
color: 'orange',
|
|
|
|
textColor: 'white'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: 'Past event 4',
|
|
|
|
start: 1660579608000,
|
|
|
|
end: 1660624108000,
|
|
|
|
type: 'TEST-GROUP',
|
|
|
|
color: 'orange',
|
|
|
|
textColor: 'white'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: 'Past event 5',
|
|
|
|
start: 1660666008000,
|
|
|
|
end: 1660681529000,
|
|
|
|
type: 'TEST-GROUP',
|
|
|
|
color: 'orange',
|
|
|
|
textColor: 'white'
|
|
|
|
}
|
|
|
|
]
|
|
|
|
};
|
|
|
|
|
|
|
|
test.describe('Time Strip', () => {
|
|
|
|
test('Create two Time Strips, add a single Plan to both, and verify they can have separate Indepdenent Time Contexts @unstable', async ({
|
|
|
|
page
|
|
|
|
}) => {
|
|
|
|
test.info().annotations.push({
|
|
|
|
type: 'issue',
|
|
|
|
description: 'https://github.com/nasa/openmct/issues/5627'
|
|
|
|
});
|
2023-05-18 21:54:46 +00:00
|
|
|
|
2022-09-10 00:31:03 +00:00
|
|
|
// Constant locators
|
|
|
|
const independentTimeConductorInputs = page.locator(
|
|
|
|
'.l-shell__main-independent-time-conductor .c-input--datetime'
|
2023-05-18 21:54:46 +00:00
|
|
|
);
|
2022-09-10 00:31:03 +00:00
|
|
|
const activityBounds = page.locator('.activity-bounds');
|
2023-05-18 21:54:46 +00:00
|
|
|
|
2022-09-10 00:31:03 +00:00
|
|
|
// Goto baseURL
|
2023-04-18 22:32:29 +00:00
|
|
|
await page.goto('./', { waitUntil: 'domcontentloaded' });
|
2023-05-18 21:54:46 +00:00
|
|
|
|
2022-09-10 00:31:03 +00:00
|
|
|
const timestrip = await test.step('Create a Time Strip', async () => {
|
|
|
|
const createdTimeStrip = await createDomainObjectWithDefaults(page, { type: 'Time Strip' });
|
|
|
|
const objectName = await page.locator('.l-browse-bar__object-name').innerText();
|
|
|
|
expect(objectName).toBe(createdTimeStrip.name);
|
2023-05-18 21:54:46 +00:00
|
|
|
|
2022-09-10 00:31:03 +00:00
|
|
|
return createdTimeStrip;
|
2023-05-18 21:54:46 +00:00
|
|
|
});
|
|
|
|
|
2022-09-10 00:31:03 +00:00
|
|
|
const plan = await test.step('Create a Plan and add it to the timestrip', async () => {
|
|
|
|
const createdPlan = await createPlanFromJSON(page, {
|
|
|
|
name: 'Test Plan',
|
|
|
|
json: testPlan
|
2023-05-18 21:54:46 +00:00
|
|
|
});
|
|
|
|
|
2022-09-10 00:31:03 +00:00
|
|
|
await page.goto(timestrip.url);
|
|
|
|
// Expand the tree to show the plan
|
|
|
|
await page.click("button[title='Show selected item in tree']");
|
|
|
|
await page.dragAndDrop(`role=treeitem[name=/${createdPlan.name}/]`, '.c-object-view');
|
|
|
|
await page.click("button[title='Save']");
|
|
|
|
await page.click("li[title='Save and Finish Editing']");
|
|
|
|
const startBound = testPlan.TEST_GROUP[0].start;
|
|
|
|
const endBound = testPlan.TEST_GROUP[testPlan.TEST_GROUP.length - 1].end;
|
2023-05-18 21:54:46 +00:00
|
|
|
|
2022-09-10 00:31:03 +00:00
|
|
|
// Switch to fixed time mode with all plan events within the bounds
|
|
|
|
await page.goto(
|
|
|
|
`${timestrip.url}?tc.mode=fixed&tc.startBound=${startBound}&tc.endBound=${endBound}&tc.timeSystem=utc&view=time-strip.view`
|
2023-05-18 21:54:46 +00:00
|
|
|
);
|
|
|
|
|
2022-09-10 00:31:03 +00:00
|
|
|
// Verify all events are displayed
|
|
|
|
const eventCount = await page.locator('.activity-bounds').count();
|
|
|
|
expect(eventCount).toEqual(testPlan.TEST_GROUP.length);
|
2023-05-18 21:54:46 +00:00
|
|
|
|
2022-09-10 00:31:03 +00:00
|
|
|
return createdPlan;
|
2023-05-18 21:54:46 +00:00
|
|
|
});
|
|
|
|
|
2022-09-10 00:31:03 +00:00
|
|
|
await test.step('TimeStrip can use the Independent Time Conductor', async () => {
|
|
|
|
// Activate Independent Time Conductor in Fixed Time Mode
|
|
|
|
await page.click('.c-toggle-switch__slider');
|
|
|
|
expect(await activityBounds.count()).toEqual(0);
|
2023-05-18 21:54:46 +00:00
|
|
|
|
2022-09-10 00:31:03 +00:00
|
|
|
// Set the independent time bounds so that only one event is shown
|
|
|
|
const startBound = testPlan.TEST_GROUP[0].start;
|
|
|
|
const endBound = testPlan.TEST_GROUP[0].end;
|
|
|
|
const startBoundString = new Date(startBound).toISOString().replace('T', ' ');
|
|
|
|
const endBoundString = new Date(endBound).toISOString().replace('T', ' ');
|
2023-05-18 21:54:46 +00:00
|
|
|
|
2022-09-10 00:31:03 +00:00
|
|
|
await independentTimeConductorInputs.nth(0).fill('');
|
|
|
|
await independentTimeConductorInputs.nth(0).fill(startBoundString);
|
|
|
|
await page.keyboard.press('Enter');
|
|
|
|
await independentTimeConductorInputs.nth(1).fill('');
|
|
|
|
await independentTimeConductorInputs.nth(1).fill(endBoundString);
|
|
|
|
await page.keyboard.press('Enter');
|
|
|
|
expect(await activityBounds.count()).toEqual(1);
|
2023-05-18 21:54:46 +00:00
|
|
|
});
|
|
|
|
|
2022-09-10 00:31:03 +00:00
|
|
|
await test.step('Can have multiple TimeStrips with the same plan linked and different Independent Time Contexts', async () => {
|
|
|
|
// Create another Time Strip and verify that it has been created
|
|
|
|
const createdTimeStrip = await createDomainObjectWithDefaults(page, {
|
|
|
|
type: 'Time Strip',
|
|
|
|
name: 'Another Time Strip'
|
2023-05-18 21:54:46 +00:00
|
|
|
});
|
|
|
|
|
2022-09-10 00:31:03 +00:00
|
|
|
const objectName = await page.locator('.l-browse-bar__object-name').innerText();
|
|
|
|
expect(objectName).toBe(createdTimeStrip.name);
|
2023-05-18 21:54:46 +00:00
|
|
|
|
2022-09-10 00:31:03 +00:00
|
|
|
// Drag the existing Plan onto the newly created Time Strip, and save.
|
|
|
|
await page.dragAndDrop(`role=treeitem[name=/${plan.name}/]`, '.c-object-view');
|
|
|
|
await page.click("button[title='Save']");
|
|
|
|
await page.click("li[title='Save and Finish Editing']");
|
2023-05-18 21:54:46 +00:00
|
|
|
|
2022-09-10 00:31:03 +00:00
|
|
|
// Activate Independent Time Conductor in Fixed Time Mode
|
|
|
|
await page.click('.c-toggle-switch__slider');
|
2023-05-18 21:54:46 +00:00
|
|
|
|
2022-09-10 00:31:03 +00:00
|
|
|
// All events should be displayed at this point because the
|
|
|
|
// initial independent context bounds will match the global bounds
|
|
|
|
expect(await activityBounds.count()).toEqual(5);
|
2023-05-18 21:54:46 +00:00
|
|
|
|
2022-09-10 00:31:03 +00:00
|
|
|
// Set the independent time bounds so that two events are shown
|
|
|
|
const startBound = testPlan.TEST_GROUP[0].start;
|
|
|
|
const endBound = testPlan.TEST_GROUP[1].end;
|
|
|
|
const startBoundString = new Date(startBound).toISOString().replace('T', ' ');
|
|
|
|
const endBoundString = new Date(endBound).toISOString().replace('T', ' ');
|
2023-05-18 21:54:46 +00:00
|
|
|
|
2022-09-10 00:31:03 +00:00
|
|
|
await independentTimeConductorInputs.nth(0).fill('');
|
|
|
|
await independentTimeConductorInputs.nth(0).fill(startBoundString);
|
|
|
|
await page.keyboard.press('Enter');
|
|
|
|
await independentTimeConductorInputs.nth(1).fill('');
|
|
|
|
await independentTimeConductorInputs.nth(1).fill(endBoundString);
|
|
|
|
await page.keyboard.press('Enter');
|
2023-05-18 21:54:46 +00:00
|
|
|
|
2022-09-10 00:31:03 +00:00
|
|
|
// Verify that two events are displayed
|
|
|
|
expect(await activityBounds.count()).toEqual(2);
|
2023-05-18 21:54:46 +00:00
|
|
|
|
2022-09-10 00:31:03 +00:00
|
|
|
// Switch to the previous Time Strip and verify that only one event is displayed
|
|
|
|
await page.goto(timestrip.url);
|
|
|
|
expect(await activityBounds.count()).toEqual(1);
|
2023-05-18 21:54:46 +00:00
|
|
|
});
|
|
|
|
});
|
2022-09-10 00:31:03 +00:00
|
|
|
});
|