|
@@ -13,18 +13,23 @@ const testURL = 'http://localhost:4567/providers'
|
|
|
|
|
|
describe('File upload with Providers', () => {
|
|
|
beforeEach(() => {
|
|
|
+
|
|
|
+ while (browser.getTabIds().length > 1) {
|
|
|
+ browser.switchTab(browser.getTabIds()[1])
|
|
|
+ browser.close()
|
|
|
+ }
|
|
|
+
|
|
|
browser.url(testURL)
|
|
|
})
|
|
|
|
|
|
|
|
|
it('should upload a file completely with Google Drive', function () {
|
|
|
- if (process.env.UPPY_GOOGLE_EMAIL || process.env.UPPY_GOOGLE_EMAIL === undefined) {
|
|
|
+ if (process.env.UPPY_GOOGLE_EMAIL == undefined) {
|
|
|
console.log('skipping Google Drive integration test')
|
|
|
return this.skip()
|
|
|
}
|
|
|
|
|
|
|
|
|
- browser.reload()
|
|
|
startUploadTest(browser, 'GoogleDrive')
|
|
|
signIntoGoogle(browser)
|
|
|
finishUploadTest(browser)
|
|
@@ -32,38 +37,66 @@ describe('File upload with Providers', () => {
|
|
|
|
|
|
|
|
|
it('should upload a file completely with Instagram', function () {
|
|
|
- if (process.env.UPPY_INSTAGRAM_USERNAME || process.env.UPPY_INSTAGRAM_USERNAME === undefined) {
|
|
|
+ const isFirefox = browser.desiredCapabilities.browserName === 'firefox'
|
|
|
+ if (process.env.UPPY_INSTAGRAM_USERNAME == undefined || !isFirefox) {
|
|
|
console.log('skipping Instagram integration test')
|
|
|
return this.skip()
|
|
|
}
|
|
|
|
|
|
|
|
|
- browser.reload()
|
|
|
startUploadTest(browser, 'Instagram')
|
|
|
|
|
|
- browser.waitForExist('input[name=username]')
|
|
|
+ browser.waitForExist('input[name=username]', 20000)
|
|
|
browser.setValue('input[name=username]', process.env.UPPY_INSTAGRAM_USERNAME)
|
|
|
browser.setValue('input[name=password]', process.env.UPPY_INSTAGRAM_PASSWORD)
|
|
|
- browser.click('form button')
|
|
|
+ browser.click('form button[type=submit]')
|
|
|
+ if (browser.getTabIds().length > 1) {
|
|
|
+
|
|
|
+ browser.pause(3000)
|
|
|
+
|
|
|
+
|
|
|
+ if (browser.isExisting('input[name="choice"]')) {
|
|
|
+ browser.click('form button')
|
|
|
+ browser.waitForExist('input[name=security_code]')
|
|
|
+
|
|
|
+
|
|
|
+ browser.waitUntil(
|
|
|
+ () => browser('input[name=security_code]').getValue(),
|
|
|
+ 30000, 'expected security code to be manually entered')
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ if (browser.isExisting('button[value="Authorize"]')) {
|
|
|
+ browser.click('button[value="Authorize"]')
|
|
|
+ }
|
|
|
+ }
|
|
|
|
|
|
finishUploadTest(browser)
|
|
|
})
|
|
|
|
|
|
|
|
|
it('should upload a file completely with Dropbox', function () {
|
|
|
- if (process.env.UPPY_GOOGLE_EMAIL || process.env.UPPY_GOOGLE_EMAIL === undefined) {
|
|
|
+ if (process.env.UPPY_GOOGLE_EMAIL === undefined) {
|
|
|
console.log('skipping Dropbox integration test')
|
|
|
return this.skip()
|
|
|
}
|
|
|
|
|
|
|
|
|
- browser.reload()
|
|
|
startUploadTest(browser, 'Dropbox')
|
|
|
|
|
|
browser.waitForVisible('button.auth-google')
|
|
|
browser.click('button.auth-google')
|
|
|
+ browser.pause(3000)
|
|
|
|
|
|
signIntoGoogle(browser)
|
|
|
+ browser.pause(5000)
|
|
|
+
|
|
|
+
|
|
|
+ if (browser.isExisting('#warning-button-continue')) {
|
|
|
+ browser.click('#warning-button-continue')
|
|
|
+ }
|
|
|
+
|
|
|
+ browser.pause(3000)
|
|
|
|
|
|
browser.waitForVisible('button[name=allow_access]')
|
|
|
browser.click('button[name=allow_access]')
|
|
@@ -92,6 +125,12 @@ const finishUploadTest = (browser) => {
|
|
|
}
|
|
|
|
|
|
const signIntoGoogle = (browser) => {
|
|
|
+ if (browser.isExisting(`li div[data-identifier="${process.env.UPPY_GOOGLE_EMAIL}"]`)) {
|
|
|
+
|
|
|
+ browser.click(`li div[data-identifier="${process.env.UPPY_GOOGLE_EMAIL}"]`)
|
|
|
+ return
|
|
|
+ }
|
|
|
+
|
|
|
browser.waitForExist('#identifierId')
|
|
|
browser.setValue('#identifierId', process.env.UPPY_GOOGLE_EMAIL)
|
|
|
browser.click('#identifierNext')
|
|
@@ -106,12 +145,13 @@ const signIntoGoogle = (browser) => {
|
|
|
browser.click('li div[data-challengetype="12"]')
|
|
|
browser.waitForVisible('input[name=knowledgePreregisteredEmailResponse]')
|
|
|
browser.setValue('input[name=knowledgePreregisteredEmailResponse]', process.env.UPPY_GOOGLE_RECOVERY_EMAIL)
|
|
|
+ browser.click('#next[role=button]')
|
|
|
|
|
|
} else if (browser.isExisting('#countryList')) {
|
|
|
browser.click('div#countryList')
|
|
|
browser.click('div[data-value=nl]')
|
|
|
browser.setValue('input#phoneNumberId', process.env.UPPY_GOOGLE_PHONE_NO)
|
|
|
+ browser.click('#next[role=button]')
|
|
|
}
|
|
|
- browser.click('#next[role=button]')
|
|
|
}
|
|
|
}
|