mirror of https://github.com/nocodb/nocodb
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
75 lines
2.3 KiB
75 lines
2.3 KiB
import { mainPage } from "../../support/page_objects/mainPage"; |
|
import { loginPage } from "../../support/page_objects/navigation"; |
|
import { |
|
isPostgres, |
|
isTestSuiteActive, |
|
} from "../../support/page_objects/projectConstants"; |
|
|
|
export const genTest = (apiType, dbType) => { |
|
if (!isTestSuiteActive(apiType, dbType)) return; |
|
|
|
describe(`${apiType.toUpperCase()} Upload/ Download CSV`, () => { |
|
before(() => { |
|
cy.setup({ dbType }) |
|
}); |
|
|
|
beforeEach(() => { |
|
cy.restoreLocalStorage(); |
|
}); |
|
|
|
afterEach(() => { |
|
cy.saveLocalStorage(); |
|
}); |
|
|
|
it("Download verification- base view, default columns", () => { |
|
cy.openTableTab("Country", 25); |
|
|
|
mainPage.hideField("LastUpdate"); |
|
const verifyCsv = (retrievedRecords) => { |
|
// expected output, statically configured |
|
// let storedRecords = [ |
|
// `Country,CityList`, |
|
// `Afghanistan,Kabul`, |
|
// `Algeria,"Batna, Bchar, Skikda"`, |
|
// `American Samoa,Tafuna`, |
|
// `Angola,"Benguela, Namibe"`, |
|
// ]; |
|
let storedRecords = [ |
|
["Country", "City List"], |
|
["Afghanistan", "Kabul"], |
|
["Algeria", "Skikda", "Bchar", "Batna"], |
|
["American Samoa", "Tafuna"], |
|
["Angola", "Benguela", "Namibe"], |
|
]; |
|
|
|
// if (isPostgres()) { |
|
// // order of second entry is different |
|
// storedRecords = [ |
|
// `Country,City List`, |
|
// `Afghanistan,Kabul`, |
|
// `Algeria,"Skikda, Bchar, Batna"`, |
|
// `American Samoa,Tafuna`, |
|
// `Angola,"Benguela, Namibe"`, |
|
// ]; |
|
// } |
|
|
|
for (let i = 0; i < storedRecords.length - 1; i++) { |
|
for (let j = 0; j < storedRecords[i].length; j++) |
|
expect(retrievedRecords[i]).to.have.string(storedRecords[i][j]); |
|
|
|
// often, the order in which records "Skikda, Bchar, Batna" appear, used to toggle |
|
// hence verifying record contents separately |
|
// expect(retrievedRecords[i]).to.be.equal(storedRecords[i]); |
|
} |
|
}; |
|
|
|
// download & verify |
|
mainPage.downloadAndVerifyCsv(`Country_exported_1.csv`, verifyCsv); |
|
mainPage.unhideField("LastUpdate"); |
|
|
|
cy.closeTableTab("Country"); |
|
}); |
|
}); |
|
}; |
|
|
|
|
|
|