462 lines
15 KiB
JavaScript
Raw Normal View History

/*
* Copyright 2021 Collate
* 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.
*/
import { searchEntity } from '../../common/common';
import { DELETE_TERM, NEW_GLOSSARY, NEW_GLOSSARY_TERMS, SEARCH_ENTITY_TABLE } from '../../constants/constants';
const createGlossaryTerm = (term) => {
cy.get('[data-testid="header"]')
.should('be.visible')
.contains(NEW_GLOSSARY.name)
.should('exist');
cy.get('[data-testid="add-new-tag-button"]').should('be.visible').click();
cy.contains('Add Glossary Term').should('be.visible');
cy.get('[data-testid="name"]')
.scrollIntoView()
.should('be.visible')
.type(term.name);
cy.get('.toastui-editor-md-container > .toastui-editor > .ProseMirror')
.scrollIntoView()
.should('be.visible')
.type(term.description);
cy.get('[data-testid="synonyms"]')
.scrollIntoView()
.should('be.visible')
.type(term.synonyms);
cy.get('[data-testid="references"] > .tw-flex > .button-comp')
.scrollIntoView()
.should('be.visible')
.click();
cy.get('#name-0').scrollIntoView().should('be.visible').type('test');
cy.get('#url-0')
.scrollIntoView()
.should('be.visible')
.type('https://test.com');
cy.get('[data-testid="save-glossary-term"]')
.scrollIntoView()
.should('be.visible')
.click();
cy.wait(200);
cy.get('#left-panel').contains(term.name).should('be.visible');
};
const deleteGlossary = ({ name }) => {
cy.get('#left-panel').contains(name).should('be.visible').click();
cy.wait(500);
cy.get('[data-testid="inactive-link"]').contains(name).should('be.visible');
cy.get('[data-testid="manage-button"]').should('be.visible').click();
cy.get('[data-testid="delete-button"]')
.scrollIntoView()
.should('be.visible')
.click();
cy.get('.tw-modal-container').should('be.visible');
cy.get('[data-testid="confirmation-text-input"]')
.should('be.visible')
.type(DELETE_TERM);
cy.get('[data-testid="confirm-button"]')
.should('be.visible')
.should('not.disabled')
.click();
cy.get('.Toastify__toast-body')
.contains('Glossary term deleted successfully!')
.should('be.visible');
cy.get('.Toastify__close-button > svg > path').should('be.visible').click();
cy.get('.tw-modal-container').should('not.exist');
cy.wait(500);
};
const goToAssetsTab = (term) => {
cy.get('#left-panel').should('be.visible').contains(term).click();
cy.wait(500);
cy.get('[data-testid="inactive-link"]').contains(term).should('be.visible');
cy.get('[data-testid="Assets"]').should('be.visible').click();
cy.get('[data-testid="Assets"]').should('have.class', 'active');
};
describe('Glossary page should work properly', () => {
beforeEach(() => {
cy.goToHomePage();
//Clicking on Glossary
cy.get('[data-testid="appbar-item-glossary"]')
.should('exist')
.should('be.visible')
.click({ force: true });
// Todo: need to remove below uncaught exception once tree-view error resolves
cy.on('uncaught:exception', () => {
// return false to prevent the error from
// failing this test
return false;
});
});
it('Create new glossary flow should work properly', () => {
// check for no data placeholder
cy.contains('No glossaries found').should('be.visible');
// Redirecting to add glossary page
cy.get('[data-testid="add-webhook-button"]').should('be.visible').click();
cy.get('.tw-form-container > .tw-heading')
.contains('Add Glossary')
.should('be.visible');
cy.get('[data-testid="name"]')
.scrollIntoView()
.should('be.visible')
.type(NEW_GLOSSARY.name);
cy.get('.toastui-editor-md-container > .toastui-editor > .ProseMirror')
.scrollIntoView()
.should('be.visible')
.type(NEW_GLOSSARY.description);
cy.get('[data-testid="add-reviewers"]')
.scrollIntoView()
.should('be.visible')
.click();
cy.get('.tw-modal-container').should('be.visible');
cy.get('.tw-grid > [data-testid="user-card-container"]')
.first()
.should('be.visible')
.as('reviewer');
cy.get('@reviewer')
.find('[data-testid="checkboxAddUser"]')
.should('be.visible')
.check();
cy.get('[data-testid="saveButton"]').should('be.visible').click();
cy.get('.tw-modal-container').should('not.exist');
cy.get('[data-testid="reviewers-container"]')
.children()
.should('have.length', 1);
cy.get('[data-testid="save-glossary"]')
.scrollIntoView()
.should('be.visible')
.click();
cy.get('[data-testid="inactive-link"]')
.should('be.visible')
.invoke('text')
.then((text) => {
expect(text).to.equal(NEW_GLOSSARY.name);
});
});
it('Create glossary term should work properly', () => {
const terms = Object.values(NEW_GLOSSARY_TERMS);
terms.forEach(createGlossaryTerm);
});
it('Updating data of glossary should work properly', () => {
const newDescription = 'Updated description';
// updating tags
cy.get('[data-testid="tag-container"]')
.scrollIntoView()
.should('be.visible')
.click();
cy.get('[class*="-control"]')
.scrollIntoView()
.should('be.visible')
.type('personal');
cy.wait(500);
cy.get('[id*="-option-0"]').scrollIntoView().should('be.visible').click();
cy.get('[data-testid="saveAssociatedTag"]').scrollIntoView().click();
cy.get('[data-testid="glossary-details"]')
.scrollIntoView()
.contains('PersonalData.Personal')
.should('be.visible');
// updating description
cy.get('[data-testid="edit-description"]').should('be.visible').click();
cy.get('.tw-modal-container').should('be.visible');
cy.get('.toastui-editor-md-container > .toastui-editor > .ProseMirror')
.should('be.visible')
.as('description');
cy.get('@description').clear();
cy.get('@description').type(newDescription);
cy.get('[data-testid="save"]').click();
cy.get('.tw-modal-container').should('not.exist');
cy.wait(1000);
cy.get('[data-testid="viewer-container"]')
.contains(newDescription)
.should('be.visible');
});
it('Updating data of glossary term should work properly', () => {
const term = NEW_GLOSSARY_TERMS.term_1.name;
const uSynonyms = 'pick up,take,obtain';
const newRef = { name: 'take', url: 'https://take.com' };
const newDescription = 'Updated description';
cy.get('#left-panel').should('be.visible').contains(term).click();
cy.wait(500);
cy.get('[data-testid="inactive-link"]').contains(term).should('be.visible');
cy.get('[data-testid="section-synonyms"]')
.scrollIntoView()
.should('be.visible')
.click();
cy.get('[data-testid="synonyms"]')
.scrollIntoView()
.should('be.visible')
.as('synonyms');
cy.get('@synonyms').clear();
cy.get('@synonyms').type(uSynonyms);
cy.intercept({ method: 'PATCH', url: '/api/v1/glossaryTerms/*' }).as(
'getGlossary'
);
cy.get('[data-testid="saveAssociatedTag"]').should('be.visible').click();
cy.wait(100);
cy.get('[data-testid="synonyms-container"]')
.as('synonyms-container')
.should('be.visible');
uSynonyms.split(',').forEach((synonym) => {
cy.get('@synonyms-container').contains(synonym).should('be.visible');
});
cy.wait('@getGlossary').its('response.statusCode').should('eq', 200);
// updating References
cy.get('[data-testid="section-references"] [data-testid="add-button"]')
.should('exist')
.click();
cy.get('.tw-modal-container').should('be.visible');
cy.get('[data-testid="references"] .button-comp')
.should('be.visible')
.click();
cy.get('#name-1').should('be.visible').type(newRef.name);
cy.get('#url-1').should('be.visible').type(newRef.url);
cy.get('[data-testid="saveButton"]').should('be.visible').click();
cy.get('[data-testid="references-container"]')
.contains(newRef.name)
.should('be.visible')
.invoke('attr', 'href')
.should('eq', newRef.url);
// updating tags
cy.get('[data-testid="tag-container"]')
.scrollIntoView()
.should('be.visible')
.click();
cy.get('[class*="-control"]')
.scrollIntoView()
.should('be.visible')
.type('personal');
cy.wait(500);
cy.get('[id*="-option-0"]').scrollIntoView().should('be.visible').click();
cy.get('[data-testid="saveAssociatedTag"]').scrollIntoView().click();
cy.get('[data-testid="glossary-term"]')
.scrollIntoView()
.contains('PersonalData.Personal')
.should('be.visible');
cy.wait(1000);
// updating description
cy.get('[data-testid="edit-description"]').should('be.visible').click();
cy.get('.tw-modal-container').should('be.visible');
cy.get('.toastui-editor-md-container > .toastui-editor > .ProseMirror')
.should('be.visible')
.as('description');
cy.get('@description').clear();
cy.get('@description').type(newDescription);
cy.get('[data-testid="save"]').click();
cy.get('.tw-modal-container').should('not.exist');
cy.wait(1000);
cy.get('[data-testid="viewer-container"]')
.contains(newDescription)
.should('be.visible');
});
// Todo: skipping for now as it flaky on CI
it.skip('Releted Terms should work properly', () => {
const term = NEW_GLOSSARY_TERMS.term_1.name;
const term2 = NEW_GLOSSARY_TERMS.term_2.name;
cy.get('#left-panel').should('be.visible').contains(term).click();
cy.wait(500);
cy.get('[data-testid="inactive-link"]').contains(term).should('be.visible');
// add releted term
cy.get('[data-testid="add-related-term-button"]')
.should('be.visible')
.click();
cy.get('.tw-modal-container').should('be.visible');
cy.wait(500);
cy.get('[data-testid="user-card-container"]')
.first()
.should('be.visible')
.find('[data-testid="checkboxAddUser"]')
.check();
cy.get('[data-testid="saveButton"]').should('be.visible').click();
cy.get('.tw-modal-container').should('not.exist');
cy.get('[data-testid="related terms-card-container"]')
.contains(term2)
.should('be.visible');
});
it('Assets Tab should work properly', () => {
const glossary = NEW_GLOSSARY.name;
const term = NEW_GLOSSARY_TERMS.term_1.name;
const entity = SEARCH_ENTITY_TABLE.table_3.term;
goToAssetsTab(term);
cy.get('.tableBody-cell')
.contains('No assets available.')
.should('be.visible');
searchEntity(entity);
cy.wait(500);
cy.get('[data-testid="table-link"]').first().contains(entity).click();
//Add tag to breadcrumb
cy.get('[data-testid="tag-container"] [data-testid="tags"]')
.eq(0)
.should('be.visible')
.click();
cy.get('[class*="-control"]').should('be.visible').type(term);
cy.wait(500);
cy.get('[id*="-option-0"]').should('be.visible').click();
cy.get(
'[data-testid="tags-wrapper"] [data-testid="tag-container"]'
).contains(term);
cy.get('[data-testid="saveAssociatedTag"]').should('be.visible').click();
cy.wait(1000);
cy.get('[data-testid="entity-tags"]')
.scrollIntoView()
.should('be.visible')
.contains(term);
//Add tag to schema table
cy.get('[data-testid="tag-container"] [data-testid="tags"]')
.eq(0)
.should('be.visible')
.click();
cy.get('[class*="-control"]').should('be.visible').type(term);
cy.wait(500);
cy.get('[id*="-option-0"]').should('be.visible').click();
cy.get(
'[data-testid="tags-wrapper"] [data-testid="tag-container"]'
).contains(term);
cy.get('[data-testid="saveAssociatedTag"]').should('be.visible').click();
cy.wait(1000);
cy.get(`[data-testid="tag-${glossary}.${term}"]`)
.scrollIntoView()
.should('be.visible')
.contains(term);
cy.get('[data-testid="appbar-item-glossary"]')
.should('exist')
.should('be.visible')
.click({ force: true });
goToAssetsTab(term);
cy.get('[data-testid="column"] > :nth-child(1)')
.contains(entity)
.should('be.visible');
});
it('Remove Glossary term from entity should work properly', () => {
const term = NEW_GLOSSARY_TERMS.term_1.name;
const entity = SEARCH_ENTITY_TABLE.table_3.term;
// go assets tab
goToAssetsTab(term);
cy.wait(1000);
cy.get('[data-testid="column"] > :nth-child(1) > a')
.contains(entity)
.should('be.visible')
.click();
cy.wait(500);
// redirect to entity detail page
cy.get('[data-testid="entity-tags"]')
.find('[data-testid="edit-button"]')
.scrollIntoView()
.should('be.visible')
.click();
cy.get('[role="button"]').eq(0).should('be.visible').click();
cy.get('[role="button"]').eq(0).should('be.visible').click();
cy.get('[data-testid="saveAssociatedTag"]').scrollIntoView().click();
//Remove the added column tag from entity
cy.get('[data-testid="remove"]').eq(0).should('be.visible').click();
cy.wait(500);
cy.get('[data-testid="remove"]').eq(0).should('be.visible').click();
cy.get('[data-testid="appbar-item-glossary"]')
.should('exist')
.should('be.visible')
.click({ force: true });
cy.wait(500);
goToAssetsTab(term);
cy.get('.tableBody-cell')
.contains('No assets available.')
.should('be.visible');
});
it('Delete glossary term should work properly', () => {
const terms = Object.values(NEW_GLOSSARY_TERMS);
terms.forEach(deleteGlossary);
});
it('Delete glossary should work properly', () => {
cy.get('[data-testid="header"]')
.should('be.visible')
.contains(NEW_GLOSSARY.name)
.should('exist');
cy.get('[data-testid="manage-button"]').should('be.visible').click();
cy.get('[data-testid="delete-button"]')
.scrollIntoView()
.should('be.visible')
.click();
cy.get('.tw-modal-container').should('be.visible');
cy.get('[data-testid="confirmation-text-input"]')
.should('be.visible')
.type(DELETE_TERM);
cy.get('[data-testid="confirm-button"]')
.should('be.visible')
.should('not.disabled')
.click();
cy.get('.Toastify__toast-body')
.contains('Glossary deleted successfully!')
.should('be.visible');
cy.get('.Toastify__close-button > svg > path').should('be.visible').click();
cy.wait(500);
cy.contains('No glossaries found').should('be.visible');
});
});