0
0
mirror of https://github.com/twbs/bootstrap.git synced 2025-01-25 17:52:20 +01:00
Bootstrap/build/saucelabs-unit-test.js

117 lines
3.2 KiB
JavaScript
Raw Normal View History

/*!
* Script to run our Sauce Labs tests.
* Copyright 2017-2018 The Bootstrap Authors
* Copyright 2017-2018 Twitter, Inc.
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
*/
/*
Docs: https://wiki.saucelabs.com/display/DOCS/Platform+Configurator
Mac Opera is not currently supported by Sauce Labs
Win Opera 15+ is not currently supported by Sauce Labs
iOS Chrome is not currently supported by Sauce Labs
*/
2017-09-28 18:18:20 +03:00
'use strict'
const path = require('path')
const JSUnitSaucelabs = require('jsunitsaucelabs')
2017-09-28 16:18:29 +03:00
const jsUnitSaucelabs = new JSUnitSaucelabs({
username: process.env.SAUCE_USERNAME,
2017-09-28 17:01:06 +03:00
password: process.env.SAUCE_ACCESS_KEY,
build: process.env.TRAVIS_JOB_ID
})
const testURL = 'http://localhost:3000/js/tests/index.html?hidepassed'
2017-09-28 18:18:20 +03:00
const browsersFile = require(path.resolve(__dirname, './sauce_browsers.json'))
const errorMessages = [
'Test exceeded maximum duration',
'Test exceeded maximum duration after 180 seconds'
]
let jobsDone = 0
let jobsSucceeded = 0
2017-09-28 18:18:20 +03:00
const waitingCallback = (error, body, id) => {
if (error) {
console.error(error)
process.exit(1)
}
2017-09-28 18:18:20 +03:00
if (typeof body !== 'undefined') {
if (!body.completed) {
setTimeout(() => {
jsUnitSaucelabs.getStatus(id, (error, body) => {
waitingCallback(error, body, id)
})
}, 2000)
} else {
const test = body['js tests'][0]
const platform = test.platform.join(', ')
let passed = false
let errorStr = false
2017-09-28 16:18:29 +03:00
2017-09-28 18:18:20 +03:00
if (test.result !== null) {
if (typeof test.result === 'string' && errorMessages.includes(test.result)) {
errorStr = test.result
} else {
passed = test.result.total === test.result.passed
}
2017-09-28 18:18:20 +03:00
}
2017-09-28 18:18:20 +03:00
console.log(`Tested ${testURL}`)
console.log(`Platform: ${platform}`)
console.log(`Passed: ${passed}`)
console.log(`URL: ${test.url}\n`)
if (errorStr) {
console.error(`${platform}: ${errorStr}`)
}
2017-09-28 18:18:20 +03:00
if (passed) {
jobsSucceeded++
}
2017-09-28 18:18:20 +03:00
jobsDone++
2017-09-28 18:18:20 +03:00
// Exit
if (jobsDone === browsersFile.length - 1) {
jsUnitSaucelabs.stop()
2017-10-10 11:50:55 +02:00
if (jobsDone > jobsSucceeded) {
const failedTests = jobsDone - jobsSucceeded
throw new Error(`${failedTests} test${failedTests > 1 ? 's' : ''} failed.`)
2017-10-10 11:50:55 +02:00
}
console.log('All tests passed')
process.exit(0)
}
}
2017-09-28 18:18:20 +03:00
}
}
jsUnitSaucelabs.on('tunnelCreated', () => {
browsersFile.forEach((tmpBrowser) => {
const browsersPlatform = typeof tmpBrowser.platform === 'undefined' ? tmpBrowser.platformName : tmpBrowser.platform
const browsersArray = [browsersPlatform, tmpBrowser.browserName, tmpBrowser.version]
jsUnitSaucelabs.start([browsersArray], testURL, 'qunit', (error, success) => {
2017-09-28 18:18:20 +03:00
if (typeof success !== 'undefined') {
const taskIds = success['js tests']
2017-12-16 14:00:38 +02:00
if (!taskIds || taskIds.length === 0) {
throw new Error('Error starting tests through Sauce Labs API')
2017-09-28 18:18:20 +03:00
}
2017-09-28 18:18:20 +03:00
taskIds.forEach((id) => {
jsUnitSaucelabs.getStatus(id, (error, body) => {
waitingCallback(error, body, id)
})
})
} else {
console.error(error)
}
})
2017-09-28 18:18:20 +03:00
})
})
2017-09-28 18:18:20 +03:00
jsUnitSaucelabs.initTunnel()