multipart.spec.js 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. var test = require('tape')
  2. var path = require('path')
  3. var chalk = require('chalk')
  4. var Driver = require('./Driver')
  5. var collectErrors = Driver.collectErrors
  6. module.exports = function (driver, platform, host) {
  7. test('multipart: upload two files ' +
  8. chalk.underline.yellow('[' +
  9. platform.os + ' ' +
  10. platform.browser + ' ' +
  11. platform.version +
  12. ']'),
  13. function (t) {
  14. t.plan(1)
  15. // Go to the example URL
  16. driver.get(host + '/examples/multipart/')
  17. // driver.manage().timeouts().implicitlyWait(5 * 1000)
  18. // Find input by css selector & pass absolute image path to it
  19. driver.findElement({css: '.UppyFormContainer .UppyForm-input'}).then(function (el) {
  20. el.sendKeys(path.join(__dirname, 'image.jpg'))
  21. el.sendKeys(path.join(__dirname, 'image2.jpg'))
  22. driver.findElement({css: '.UppyForm-uploadBtn'}).click()
  23. })
  24. function isUploaded () {
  25. // .getText() only works on visible elements, so we use .getAttribute('textContent'), go figure
  26. // http://stackoverflow.com/questions/21994261/gettext-not-working-on-a-select-from-dropdown
  27. return driver.findElement({css: '.UppyProgressBar .UppyProgressBar-percentage'})
  28. .getAttribute('textContent')
  29. .then(function (value) {
  30. var progress = parseInt(value)
  31. var isFileUploaded = progress === 100
  32. return isFileUploaded
  33. })
  34. }
  35. driver.wait(isUploaded, 15000, 'File image.jpg should be uploaded within 15 seconds')
  36. .then(function (result) {
  37. collectErrors(driver).then(function () {
  38. t.equal(result, true)
  39. driver.quit()
  40. })
  41. })
  42. .catch(function (err) {
  43. collectErrors(driver).then(function () {
  44. t.fail(err)
  45. driver.quit()
  46. })
  47. })
  48. })
  49. }