mirror of
https://github.com/DSpace/dspace-angular.git
synced 2025-10-07 10:04:11 +00:00
Improve accessibility testing on Submission page
This commit is contained in:
@@ -1,8 +1,10 @@
|
|||||||
import { TEST_SUBMIT_USER, TEST_SUBMIT_USER_PASSWORD, TEST_SUBMIT_COLLECTION_NAME, TEST_SUBMIT_COLLECTION_UUID } from 'cypress/support/e2e';
|
import { testA11y } from 'cypress/support/utils';
|
||||||
|
import { TEST_SUBMIT_USER, TEST_SUBMIT_USER_PASSWORD, TEST_SUBMIT_COLLECTION_NAME, TEST_SUBMIT_COLLECTION_UUID, TEST_ADMIN_USER, TEST_ADMIN_PASSWORD } from 'cypress/support/e2e';
|
||||||
|
import { Options } from 'cypress-axe';
|
||||||
|
|
||||||
describe('New Submission page', () => {
|
describe('New Submission page', () => {
|
||||||
// NOTE: We already test that new submissions can be started from MyDSpace in my-dspace.spec.ts
|
|
||||||
|
|
||||||
|
// NOTE: We already test that new Item submissions can be started from MyDSpace in my-dspace.spec.ts
|
||||||
it('should create a new submission when using /submit path & pass accessibility', () => {
|
it('should create a new submission when using /submit path & pass accessibility', () => {
|
||||||
// Test that calling /submit with collection & entityType will create a new submission
|
// Test that calling /submit with collection & entityType will create a new submission
|
||||||
cy.visit('/submit?collection='.concat(TEST_SUBMIT_COLLECTION_UUID).concat('&entityType=none'));
|
cy.visit('/submit?collection='.concat(TEST_SUBMIT_COLLECTION_UUID).concat('&entityType=none'));
|
||||||
@@ -25,6 +27,22 @@ describe('New Submission page', () => {
|
|||||||
cy.get('div#section_upload').should('be.visible');
|
cy.get('div#section_upload').should('be.visible');
|
||||||
cy.get('div#section_license').should('be.visible');
|
cy.get('div#section_license').should('be.visible');
|
||||||
|
|
||||||
|
// Test entire page for accessibility
|
||||||
|
testA11y('ds-submission-edit',
|
||||||
|
{
|
||||||
|
rules: {
|
||||||
|
// Author & Subject fields have invalid "aria-multiline" attrs, see #1272
|
||||||
|
'aria-allowed-attr': { enabled: false },
|
||||||
|
// All panels are accordians & fail "aria-required-children" and "nested-interactive". Seem to require updating ng-bootstrap and #2216
|
||||||
|
'aria-required-children': { enabled: false },
|
||||||
|
'nested-interactive': { enabled: false },
|
||||||
|
// All select boxes fail to have a name / aria-label. This is a bug in ng-dynamic-forms and may require #2216
|
||||||
|
'select-name': { enabled: false },
|
||||||
|
}
|
||||||
|
|
||||||
|
} as Options
|
||||||
|
);
|
||||||
|
|
||||||
// Discard button should work
|
// Discard button should work
|
||||||
// Clicking it will display a confirmation, which we will confirm with another click
|
// Clicking it will display a confirmation, which we will confirm with another click
|
||||||
cy.get('button#discard').click();
|
cy.get('button#discard').click();
|
||||||
@@ -131,4 +149,69 @@ describe('New Submission page', () => {
|
|||||||
cy.get('ds-notification div.alert-success').should('be.visible');
|
cy.get('ds-notification div.alert-success').should('be.visible');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('is possible to submit a new "Person" and that form passes accessibility', () => {
|
||||||
|
// To submit a different entity type, we'll start from MyDSpace
|
||||||
|
cy.visit('/mydspace');
|
||||||
|
|
||||||
|
// This page is restricted, so we will be shown the login form. Fill it out & submit.
|
||||||
|
// NOTE: At this time, we MUST login as admin to submit Person objects
|
||||||
|
cy.loginViaForm(TEST_ADMIN_USER, TEST_ADMIN_PASSWORD);
|
||||||
|
|
||||||
|
// Open the New Submission dropdown
|
||||||
|
cy.get('button[data-test="submission-dropdown"]').click();
|
||||||
|
// Click on the "Person" type in that dropdown
|
||||||
|
cy.get('#entityControlsDropdownMenu button[title="Person"]').click();
|
||||||
|
|
||||||
|
// This should display the <ds-create-item-parent-selector> (popup window)
|
||||||
|
cy.get('ds-create-item-parent-selector').should('be.visible');
|
||||||
|
|
||||||
|
// Click on the first Collection button to seelect a collection (actual collection doesn't matter)
|
||||||
|
cy.get('ds-authorized-collection-selector button:first-child').click();
|
||||||
|
|
||||||
|
// New URL should include /workspaceitems, as we've started a new submission
|
||||||
|
cy.url().should('include', '/workspaceitems');
|
||||||
|
|
||||||
|
// The Submission edit form tag should be visible
|
||||||
|
cy.get('ds-submission-edit').should('be.visible');
|
||||||
|
|
||||||
|
// 3 sections should be visible by default
|
||||||
|
cy.get('div#section_personStep').should('be.visible');
|
||||||
|
cy.get('div#section_upload').should('be.visible');
|
||||||
|
cy.get('div#section_license').should('be.visible');
|
||||||
|
|
||||||
|
// Test entire page for accessibility
|
||||||
|
testA11y('ds-submission-edit',
|
||||||
|
{
|
||||||
|
rules: {
|
||||||
|
// All panels are accordians & fail "aria-required-children" and "nested-interactive". Seem to require updating ng-bootstrap and #2216
|
||||||
|
'aria-required-children': { enabled: false },
|
||||||
|
'nested-interactive': { enabled: false },
|
||||||
|
}
|
||||||
|
|
||||||
|
} as Options
|
||||||
|
);
|
||||||
|
|
||||||
|
// Click the lookup button next to "Publication" field
|
||||||
|
cy.get('button[data-test="lookup-button"]').click();
|
||||||
|
|
||||||
|
// A popup modal window should be visible
|
||||||
|
cy.get('ds-dynamic-lookup-relation-modal').should('be.visible');
|
||||||
|
|
||||||
|
// Popup modal should also pass accessibility tests
|
||||||
|
//testA11y('ds-dynamic-lookup-relation-modal');
|
||||||
|
testA11y({
|
||||||
|
include: ['ds-dynamic-lookup-relation-modal'],
|
||||||
|
exclude: [
|
||||||
|
['ul.nav-tabs'] // Tabs at top of model have several issues which seem to be caused by ng-bootstrap
|
||||||
|
],
|
||||||
|
});
|
||||||
|
|
||||||
|
// Close popup window
|
||||||
|
cy.get('ds-dynamic-lookup-relation-modal button.close').click();
|
||||||
|
|
||||||
|
// Back on the form, click the discard button to remove new submission
|
||||||
|
// Clicking it will display a confirmation, which we will confirm with another click
|
||||||
|
cy.get('button#discard').click();
|
||||||
|
cy.get('button#discard_submit').click();
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
Reference in New Issue
Block a user