test.js 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. /* global browser, expect */
  2. const path = require('path')
  3. const { spawn } = require('child_process')
  4. const testURL = 'http://localhost:4567/providers'
  5. describe('File upload with Providers', () => {
  6. let companion
  7. function prematureExit () {
  8. throw new Error('Companion exited early')
  9. }
  10. before(() => {
  11. companion = spawn('node', [
  12. path.join(__dirname, '../../../packages/@uppy/companion/lib/standalone/start-server')
  13. ], {
  14. stdio: 'pipe',
  15. env: Object.assign({}, process.env, {
  16. UPPYSERVER_DATADIR: path.join(__dirname, '../../../output'),
  17. UPPYSERVER_DOMAIN: 'localhost:3020',
  18. UPPYSERVER_PROTOCOL: 'http',
  19. UPPYSERVER_PORT: 3020,
  20. UPPY_ENDPOINTS: '',
  21. UPPYSERVER_SECRET: 'test'
  22. })
  23. })
  24. return new Promise((resolve, reject) => {
  25. companion.on('error', reject)
  26. companion.stdout.on('data', (chunk) => {
  27. if (`${chunk}`.includes('Listening on')) {
  28. resolve()
  29. }
  30. })
  31. companion.on('error', console.error)
  32. companion.stderr.pipe(process.stderr)
  33. companion.on('exit', prematureExit)
  34. })
  35. })
  36. after(() => {
  37. return new Promise((resolve) => {
  38. companion.removeListener('exit', prematureExit)
  39. companion.on('exit', () => resolve())
  40. companion.kill('SIGINT')
  41. })
  42. })
  43. beforeEach(() => {
  44. browser.url(testURL)
  45. })
  46. afterEach(() => {
  47. browser.reload()
  48. })
  49. // not using arrow functions as cb so to keep mocha in the 'this' context
  50. it('should upload a file completely with Google Drive', function () {
  51. if (process.env.UPPY_GOOGLE_EMAIL === undefined) {
  52. console.log('skipping Google Drive integration test')
  53. return this.skip()
  54. }
  55. startUploadTest(browser, 'GoogleDrive')
  56. signIntoGoogle(browser)
  57. finishUploadTest(browser)
  58. })
  59. // not using arrow functions as cb so to keep mocha in the 'this' context
  60. it('should upload a file completely with Instagram', function () {
  61. if (process.env.UPPY_INSTAGRAM_USERNAME === undefined) {
  62. console.log('skipping Instagram integration test')
  63. return this.skip()
  64. }
  65. startUploadTest(browser, 'Instagram')
  66. // do oauth authentication
  67. browser.waitForExist('input[name=username]')
  68. browser.setValue('input[name=username]', process.env.UPPY_INSTAGRAM_USERNAME)
  69. browser.setValue('input[name=password]', process.env.UPPY_INSTAGRAM_PASSWORD)
  70. browser.click('form button')
  71. finishUploadTest(browser)
  72. })
  73. // not using arrow functions as cb so to keep mocha in the 'this' context
  74. it('should upload a file completely with Dropbox', function () {
  75. if (process.env.UPPY_GOOGLE_EMAIL === undefined) {
  76. console.log('skipping Dropbox integration test')
  77. return this.skip()
  78. }
  79. startUploadTest(browser, 'Dropbox')
  80. // do oauth authentication
  81. browser.waitForVisible('button.auth-google')
  82. browser.click('button.auth-google')
  83. // we login with google to avoid captcha
  84. signIntoGoogle(browser)
  85. // finish oauth
  86. browser.waitForVisible('button[name=allow_access]')
  87. browser.click('button[name=allow_access]')
  88. finishUploadTest(browser)
  89. })
  90. })
  91. const startUploadTest = (browser, providerName) => {
  92. browser.click(`.uppy-DashboardTab-btn[aria-controls=uppy-DashboardContent-panel--${providerName}]`)
  93. browser.waitForVisible('.uppy-Provider-authBtn', 3000)
  94. browser.click('.uppy-Provider-authBtn')
  95. // move control to instagram auth tab
  96. browser.switchTab(browser.getTabIds()[1])
  97. }
  98. const finishUploadTest = (browser) => {
  99. // switch back to uppy tab
  100. browser.switchTab(browser.getTabIds()[0])
  101. browser.waitForVisible('.uppy-ProviderBrowser-list li.uppy-ProviderBrowserItem')
  102. browser.click('.uppy-ProviderBrowser-list li.uppy-ProviderBrowserItem:last-child button')
  103. browser.waitForVisible('.uppy-ProviderBrowser-footer .uppy-u-reset.uppy-c-btn.uppy-c-btn-primary')
  104. browser.click('.uppy-ProviderBrowser-footer .uppy-u-reset.uppy-c-btn.uppy-c-btn-primary')
  105. browser.waitForVisible('.uppy-StatusBar-content[title="Complete"]', 20000)
  106. }
  107. const signIntoGoogle = (browser) => {
  108. browser.waitForExist('#identifierId')
  109. browser.setValue('#identifierId', process.env.UPPY_GOOGLE_EMAIL)
  110. browser.click('#identifierNext')
  111. browser.waitForVisible('input[name=password]')
  112. browser.setValue('input[name=password]', process.env.UPPY_GOOGLE_PASSWORD)
  113. browser.click('#passwordNext')
  114. // if suspicious login was detected, the window will remain unclosed
  115. // so we have to confirm the recovery email or phone no
  116. if (browser.getTabIds().length > 1) {
  117. // confirm recovery email option
  118. if (browser.isExisting('li div[data-challengetype="12"]')) {
  119. browser.click('li div[data-challengetype="12"]')
  120. browser.waitForVisible('input[name=knowledgePreregisteredEmailResponse]')
  121. browser.setValue('input[name=knowledgePreregisteredEmailResponse]', process.env.UPPY_GOOGLE_RECOVERY_EMAIL)
  122. // confirm recovery phone number
  123. } else if (browser.isExisting('#countryList')) {
  124. browser.click('div#countryList')
  125. browser.click('div[data-value=nl]')
  126. browser.setValue('input#phoneNumberId', process.env.UPPY_GOOGLE_PHONE_NO)
  127. }
  128. browser.click('#next[role=button]')
  129. }
  130. }