test: Added tests for transpose functionalities, #3426 (#3650)

* test: Added tests for transpose functionalities, #3426
This commit is contained in:
Florian Giroud 2021-02-18 15:15:29 +01:00 committed by GitHub
parent 0c5742771c
commit c5f3d700a3
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 297 additions and 1 deletions

View File

@ -0,0 +1,122 @@
/**
* The following scenarios are inspired by the official OpenRefine documentation
* https://docs.openrefine.org/manual/transposing/
*/
describe(__filename, function () {
/**
* https://docs.openrefine.org/manual/transposing/#one-column
*/
it('Transpose cells across columns into rows (One column)', function () {
const fixture = [
['Name', 'Street', 'City', 'State/Province', 'Country', 'Postal code'],
['Jacques Cousteau', '23 quai de Conti', 'Paris', '', 'France', '75270'],
[
'Emmy Noether',
'010 N Merion Avenue',
'Bryn Mawr',
'Pennsylvania',
'USA',
'19010',
],
];
cy.loadAndVisitProject(fixture);
cy.columnActionClick('Street', [
'Transpose',
'Transpose cells across columns into rows...',
]);
cy.get('.dialog-container select[bind="fromColumnSelect"]').select(
'Street'
);
cy.get('.dialog-container select[bind="toColumnSelect"]').select(
'(last column)'
);
// add the column name and "test" string to each transposed cell
cy.get('label')
.contains("prepend the original column's name to each cell")
.click();
cy.get('input[bind="separatorInput"]').type(' test ');
cy.get('.dialog-container label').contains('One column').click();
cy.get('.dialog-container label')
.contains('One column')
.parent()
.find('input')
.type('Address');
cy.confirmDialogPanel();
cy.waitForOrOperation();
cy.assertNotificationContainingText(
'Transpose cells in columns starting with Street'
);
cy.assertGridEquals([
['Name', 'Address'],
['Jacques Cousteau', 'Street: test 23 quai de Conti'],
['', 'City: test Paris'],
['', 'Country: test France'],
['', 'Postal code: test 75270'],
['Emmy Noether', 'Street: test 010 N Merion Avenue'],
['', 'City: test Bryn Mawr'],
['', 'State/Province: test Pennsylvania'],
['', 'Country: test USA'],
['', 'Postal code: test 19010'],
]);
});
/**
* https://docs.openrefine.org/manual/transposing/#two-columns
*/
it('Transpose cells across columns into rows (Two columns)', function () {
const fixture = [
['Name', 'Street', 'City', 'State/Province', 'Country', 'Postal code'],
['Jacques Cousteau', '23 quai de Conti', 'Paris', '', 'France', '75270'],
[
'Emmy Noether',
'010 N Merion Avenue',
'Bryn Mawr',
'Pennsylvania',
'USA',
'19010',
],
];
cy.loadAndVisitProject(fixture);
cy.columnActionClick('Street', [
'Transpose',
'Transpose cells across columns into rows...',
]);
cy.get('.dialog-container label').contains('Two new columns').click();
cy.get('.dialog-container input[bind="keyColumnNameInput"]').type(
'Address part'
);
cy.get('.dialog-container input[bind="valueColumnNameInput"]').type(
'Address'
);
cy.confirmDialogPanel();
cy.waitForOrOperation();
cy.assertNotificationContainingText(
'Transpose cells in columns starting with Street'
);
cy.assertGridEquals([
['Name', 'Address part', 'Address'],
['Jacques Cousteau', 'Street', '23 quai de Conti'],
['', 'City', 'Paris'],
['', 'Country', 'France'],
['', 'Postal code', '75270'],
['Emmy Noether', 'Street', '010 N Merion Avenue'],
['', 'City', 'Bryn Mawr'],
['', 'State/Province', 'Pennsylvania'],
['', 'Country', 'USA'],
['', 'Postal code', '19010'],
]);
});
});

View File

@ -0,0 +1,43 @@
/**
* The following scenarios are inspired by the official OpenRefine documentation
* https://docs.openrefine.org/manual/transposing/
*/
describe(__filename, function () {
/**
* https://docs.openrefine.org/manual/transposing/#transpose-cells-in-rows-into-columns
*/
it('Transpose cells in rows into columns', function () {
const fixture = [
['Employee'],
['Employee: Karen Chiu'],
['Job title: Senior analyst'],
['Office: New York'],
['Employee: Joe Khoury'],
['Job title: Junior analyst'],
['Office: Beirut'],
['Employee: Samantha Martinez'],
['Job title: CTO'],
['Office: Tokyo'],
];
cy.loadAndVisitProject(fixture);
// the number of columns is prompted with an alert
// need to mock it
cy.window().then(($win) => {
cy.stub($win, 'prompt').returns('3');
});
cy.columnActionClick('Employee', [
'Transpose',
'Transpose cells in rows into columns...',
]);
const expected = [
['Employee 1', 'Employee 2', 'Employee 3'],
['Employee: Karen Chiu', 'Job title: Senior analyst', 'Office: New York'],
['Employee: Joe Khoury', 'Job title: Junior analyst', 'Office: Beirut'],
['Employee: Samantha Martinez', 'Job title: CTO', 'Office: Tokyo'],
];
cy.assertGridEquals(expected);
});
});

View File

@ -0,0 +1,81 @@
/**
* The following scenarios are inspired by the official OpenRefine documentation
* https://docs.openrefine.org/manual/transposing/
*/
describe(__filename, function () {
/**
* https://docs.openrefine.org/manual/transposing/#columnize-by-keyvalue-columns
* and https://docs.openrefine.org/manual/transposing/#notes-column
*/
it('Columnize by key/value columns', function () {
const fixture = [
['Field', 'Data', 'Source'],
['Name', 'Galanthus nivalis', 'IUCN'],
['Color', 'White', 'Contributed by Martha'],
['IUCN ID', '162168', ''],
['Name', 'Narcissus cyclamineus', 'Legacy'],
['Color', 'Yellow', '2009 survey'],
['IUCN ID', '161899', ''],
];
cy.loadAndVisitProject(fixture);
cy.columnActionClick('Field', [
'Transpose',
'Columnize by key/value columns...',
]);
cy.get('select[bind="keyColumnSelect"]').select('Field');
cy.get('select[bind="valueColumnSelect"]').select('Data');
cy.get('select[bind="noteColumnSelect"]').select('Source');
cy.confirmDialogPanel();
cy.waitForOrOperation();
cy.assertNotificationContainingText(
'Columnize by key column Field and value column Data with note column Source'
);
const expected = [
['Name', 'Color', 'IUCN ID', 'Source : Name', 'Source : Color'],
['Galanthus nivalis', 'White', '162168', 'IUCN', 'Contributed by Martha'],
['Narcissus cyclamineus', 'Yellow', '161899', 'Legacy', '2009 survey'],
];
cy.assertGridEquals(expected);
});
/**
* https://docs.openrefine.org/manual/transposing/#extra-columns
* Extra column Wikidata ID must be preserved
*/
it('Columnize by key/value columns + Extra columns', function () {
const fixture = [
['Field', 'Data', 'Wikidata ID'],
['Name', 'Galanthus nivalis', 'Q109995'],
['Color', 'White', 'Q109995'],
['IUCN ID', '162168', 'Q109995'],
['Name', 'Narcissus cyclamineus', 'Q1727024'],
['Color', 'Yellow', 'Q1727024'],
['IUCN ID', '161899', 'Q1727024'],
];
cy.loadAndVisitProject(fixture);
cy.columnActionClick('Field', [
'Transpose',
'Columnize by key/value columns...',
]);
cy.get('select[bind="keyColumnSelect"]').select('Field');
cy.get('select[bind="valueColumnSelect"]').select('Data');
cy.confirmDialogPanel();
cy.waitForOrOperation();
cy.assertNotificationContainingText(
'Columnize by key column Field and value column Data'
);
const expected = [
['Wikidata ID', 'Name', 'Color', 'IUCN ID'],
['Q109995', 'Galanthus nivalis', 'White', '162168'],
['Q1727024', 'Narcissus cyclamineus', 'Yellow', '161899'],
];
cy.assertGridEquals(expected);
});
});

View File

@ -145,6 +145,56 @@ Cypress.Commands.add('assertCellEquals', (rowIndex, columnName, value) => {
}); });
}); });
/**
* Make an assertion about the content of the whole grid
* The values parameter is the same as the one provided in fixtures
* Example
* cy.assertGridEquals(
* [
* ['Column A', 'Column B', 'Column C'],
* ['Row 0 A', 'Row 0 B', 'Row 0 C'],
* ['Row 1 A', 'Row 1 B', 'Row 1 C']
* ]
* )
*/
Cypress.Commands.add('assertGridEquals', (values) => {
// 1. Collect headers first
const columnNames = [];
cy.get('.data-table thead th.column-header', { log: false }).then(
($headers) => {
cy.wrap($headers, { log: false }).each(($header) => {
const columnName = $header.text().trim();
if (columnName != 'All') {
columnNames.push(columnName);
}
});
}
);
// 2. Collect grid content and make one single assertion with deep.equal
const gridValues = [];
cy.get('.data-table tbody tr', { log: false })
.each(($row) => {
// cy.log($row.index());
const rowIndex = $row.index();
gridValues[rowIndex] = [];
cy.wrap($row, { log: false })
.find('td', { log: false })
.each(($td) => {
// cy.log($td.index());
if ($td.index() > 2) {
gridValues[rowIndex][$td.index() - 3] = $td.text().trim();
if (gridValues[rowIndex][$td.index() - 3] == 'null') {
gridValues[rowIndex][$td.index() - 3] = '';
}
}
});
})
.then(() => {
gridValues.unshift(columnNames);
expect(gridValues).to.deep.equal(values);
});
});
/** /**
* Navigate to one of the entries of the main left menu of OpenRefine (Create Project, Open Project, Import Project, Language Settings) * Navigate to one of the entries of the main left menu of OpenRefine (Create Project, Open Project, Import Project, Language Settings)
*/ */
@ -225,7 +275,7 @@ Cypress.Commands.add(
); );
Cypress.Commands.add('assertNotificationContainingText', (text) => { Cypress.Commands.add('assertNotificationContainingText', (text) => {
cy.get('#notification').should('to.contain', text); cy.get('#notification').should('to.contain', text).should('be.visible');
}); });
Cypress.Commands.add( Cypress.Commands.add(