104 lines
3.5 KiB
JavaScript
104 lines
3.5 KiB
JavaScript
describe('OHIF MPR', () => {
|
|
beforeEach(() => {
|
|
cy.checkStudyRouteInViewer('1.3.6.1.4.1.25403.345050719074.3824.20170125113417.1');
|
|
cy.expectMinimumThumbnails(3);
|
|
cy.initCornerstoneToolsAliases();
|
|
cy.initCommonElementsAliases();
|
|
});
|
|
|
|
it('should not go MPR for non reconstructible displaySets', () => {
|
|
cy.get('[data-cy="MPR"]').should('have.class', 'ohif-disabled');
|
|
});
|
|
|
|
it('should go MPR for reconstructible displaySets and come back', () => {
|
|
cy.wait(250);
|
|
cy.get('[data-cy="study-browser-thumbnail"][data-series="4"]').dblclick();
|
|
cy.wait(250);
|
|
|
|
cy.get('[data-cy="MPR"]').click();
|
|
|
|
cy.get('.cornerstone-canvas').should('have.length', 3);
|
|
|
|
cy.get('[data-cy="MPR"]').click();
|
|
|
|
cy.get('.cornerstone-canvas').should('have.length', 1);
|
|
});
|
|
|
|
it('should render correctly the MPR', () => {
|
|
cy.wait(250);
|
|
|
|
cy.get('[data-cy="study-browser-thumbnail"][data-series="4"]').dblclick();
|
|
cy.wait(250);
|
|
cy.get('[data-cy="MPR"]').click();
|
|
|
|
cy.get('.cornerstone-canvas').should('have.length', 3);
|
|
|
|
// check cornerstone to see if each has images
|
|
// we can later do visual testing to match the images with a baseline
|
|
cy.window()
|
|
.its('cornerstone')
|
|
.then(cornerstone => {
|
|
const viewports = cornerstone.getRenderingEngines()[0].getViewports();
|
|
|
|
// The stack viewport still exists after the changes to viewportId and inde
|
|
const imageData1 = viewports[0].getImageData();
|
|
const imageData2 = viewports[1].getImageData();
|
|
const imageData3 = viewports[2].getImageData();
|
|
|
|
// for some reason map doesn't work here
|
|
cy.wrap(imageData1).should('not.be', undefined);
|
|
cy.wrap(imageData2).should('not.be', undefined);
|
|
cy.wrap(imageData3).should('not.be', undefined);
|
|
|
|
cy.wrap(imageData1.dimensions).should('deep.equal', imageData2.dimensions);
|
|
|
|
cy.wrap(imageData1.origin).should('deep.equal', imageData2.origin);
|
|
});
|
|
|
|
cy.get('[data-cy="MPR"]').click();
|
|
|
|
cy.get('.cornerstone-canvas').should('have.length', 1);
|
|
});
|
|
|
|
it('should correctly render Crosshairs for MPR', () => {
|
|
cy.get('[data-cy="study-browser-thumbnail"][data-series="4"]').dblclick();
|
|
cy.get('[data-cy="MPR"]').click();
|
|
cy.get('[data-cy="Crosshairs"]').click();
|
|
|
|
cy.wait(250);
|
|
|
|
// check cornerstone to see if each has crosshairs
|
|
// we can later do visual testing to match the images with a baseline
|
|
cy.window()
|
|
.its('cornerstoneTools')
|
|
.then(cornerstoneTools => {
|
|
const state = cornerstoneTools.annotation.state.getAnnotationManager();
|
|
|
|
const fORMap = state.annotations;
|
|
const fOR = Object.keys(fORMap)[0];
|
|
const fORAnnotation = fORMap[fOR];
|
|
|
|
// it should have crosshairs as the only key (references lines make this 2)
|
|
expect(Object.keys(fORAnnotation)).to.have.length(2);
|
|
|
|
const crosshairs = fORAnnotation.Crosshairs;
|
|
|
|
// it should have three
|
|
expect(crosshairs).to.have.length(3);
|
|
|
|
expect(crosshairs[0].data.handles.toolCenter).to.deep.equal(
|
|
crosshairs[1].data.handles.toolCenter
|
|
);
|
|
});
|
|
});
|
|
|
|
it('should activate window level when the active Crosshairs tool for MPR is clicked', () => {
|
|
cy.get('[data-cy="study-browser-thumbnail"][data-series="4"]').dblclick();
|
|
cy.get('[data-cy="MPR"]').click();
|
|
cy.get('[data-cy="Crosshairs"]').click();
|
|
|
|
// Click the crosshairs button to deactivate it.
|
|
cy.get('[data-cy="Crosshairs"]').click();
|
|
});
|
|
});
|