Skip to content

Commit

Permalink
test: Transpile tests to run older browsers in browserstack
Browse files Browse the repository at this point in the history
  • Loading branch information
rmi22186 committed Oct 25, 2023
1 parent c3a125d commit 30b4108
Show file tree
Hide file tree
Showing 8 changed files with 38,561 additions and 42 deletions.
3 changes: 2 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -10,4 +10,5 @@ test/stub/test-stub-bundle.js
**/dist
test/integrations/requirejs/test-requirejs-bundle.js
browserstack.err
local.log
local.log
test/cross-browser-testing/CBT-tests-es5.js
38,458 changes: 38,458 additions & 0 deletions package-lock.json

Large diffs are not rendered by default.

5 changes: 4 additions & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@
"build:esm": "cross-env ENVIRONMENT=prod BUILD=esm rollup --config rollup.config.js",
"build:stub": "cross-env ENVIRONMENT=prod BUILD=stub rollup --config rollup.config.js",
"build:snippet": "uglifyjs snippet.js -m -o snippet.min.js",
"build:tests": "cross-env ENVIRONMENT=prod BUILD=tests rollup --config rollup.config.js",
"build:test-bundle": "cross-env TESTTYPE=main ENVIRONMENT=prod rollup --config rollup.test.config.js",
"build:browserify:cjs": "browserify test/integrations/cjs/browserify/index.js -o test/integrations/cjs/dist/browserify-output.js",
"build:rollup:cjs": "rollup --config test/integrations/cjs/rollup/rollup.config.js",
Expand All @@ -39,6 +40,7 @@
"test": "npm run build && npm run build:test-bundle && cross-env DEBUG=false karma start test/karma.config.js",
"test:browserstack": "karma start test/cross-browser-testing/browserstack.karma.config.js",
"test:browserstack:debug": "cross-env DEBUG=true karma start test/cross-browser-testing/browserstack.karma.config.js",
"build:CBT": "rollup --config test/cross-browser-testing/rollup.CBT.config.js && rm test/cross-browser-testing/CBT-tests.js",
"test:debug": "cross-env DEBUG=true karma start test/karma.config.js",
"test:stub": "cross-env TESTTYPE=stub ENVIRONMENT=prod rollup --config rollup.test.config.js && karma start test/stub/karma.stub.config.js",
"test:integrations": "npm run test:requirejs && npm run test:integrations:cjs && npm run test:integrations:module",
Expand Down Expand Up @@ -138,6 +140,7 @@
"webpack-cli": "^5.0.2"
},
"dependencies": {
"@babel/runtime": "^7.6.0"
"@babel/runtime": "^7.23.2",
"core-js": "^3.33.0"
}
}
12 changes: 12 additions & 0 deletions test/cross-browser-testing/babel.config.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
export default {
"presets": [
[
"@babel/preset-env",
{
"useBuiltIns": "usage",
"corejs": "3.33",
},
]
],
"plugins": ['@babel/plugin-transform-runtime'],
}
41 changes: 10 additions & 31 deletions test/cross-browser-testing/browserstack.karma.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,12 +2,8 @@ const { DEBUG } = process.env;

const files = [
'../lib/geomock.js',
'../../node_modules/fetch-mock/dist/es5/client-bundle.js',
'../../dist/mparticle.js',
// TODO: the current test suite includes modern syntax which run successfully
// on newer browsers. We will need to transpile tests to work with older
// browsers - go.mparticle.com/work/SQDSDKS-5834
'../test-bundle.js',
'./CBT-tests-es5.js',
];

let captureConsole = false;
Expand All @@ -28,39 +24,22 @@ if (DEBUG === 'true') {
}

const customLaunchers = {
// These 2 browsers pass because they are capable of running ES6 syntax
// Our tests currently have ES6 syntax in them. They need to be transpiled
bs_firefox_mac_100: {
// Fails a few tests related to setTimeout
bs_chrome_mac_48: {
base: 'BrowserStack',
browser: 'firefox',
browser_version: '100.0',
browser: 'chrome',
browser_version: '48.0',
os: 'OS X',
os_version: 'Ventura'
os_version: 'Mojave'
},
bs_chrome_mac_100: {
// Oldest Chrome version to pass all tests
bs_chrome_mac_49: {
base: 'BrowserStack',
browser: 'chrome',
browser_version: '100.0',
browser_version: '49.0',
os: 'OS X',
os_version: 'Ventura'
os_version: 'Mojave'
},
// These two browsers fail because they cannot run ES6 syntax.
// Our tests have some ES6 syntax in them, so we need to transpile the tests
// to get them to run properly.
// bs_firefox_mac_21: {
// base: 'BrowserStack',
// browser: 'firefox',
// browser_version: '21.0',
// os: 'OS X',
// os_version: 'Snow Leopard'
// },
// bs_chrome_mac_38: {
// base: 'BrowserStack',
// browser: 'chrome',
// browser_version: '38.0',
// os: 'OS X',
// os_version: 'Mojave'
// },
}

module.exports = function(config) {
Expand Down
63 changes: 63 additions & 0 deletions test/cross-browser-testing/rollup.CBT.config.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,63 @@
import resolve from '@rollup/plugin-node-resolve';
import babel from '@rollup/plugin-babel';
import commonjs from '@rollup/plugin-commonjs';
import babelSettings from './babel.config.js'
const extensions = ['.js', '.ts'];
import typescript from '@rollup/plugin-typescript';
import json from '@rollup/plugin-json';

export default [
{
input: 'test/src/tests-main.js',
output: {
file: 'test/cross-browser-testing/CBT-tests.js',
format: 'umd',
name: 'mParticleTests',
},
plugins: [
resolve({
preferBuiltins: true,
}),
commonjs({
include: 'node_modules/**',
}),
typescript({
tsconfig: './tsconfig.json',
sourceMap: false,
}),
babel({
presets: ['@babel/preset-env'],
plugins: ['@babel/plugin-transform-runtime'],
extensions,
// ...babelSettings,
// exclude: ['node_modules/**/*'],
babelHelpers: 'runtime',
}),
json()
],
},
{
input: 'test/cross-browser-testing/CBT-tests.js',
output: {
file: 'test/cross-browser-testing/CBT-tests-es5.js',
format: 'umd',
name: 'mParticleTests',
},
plugins: [
resolve({
preferBuiltins: true
}),
commonjs({
include: 'node_modules/**',
}),
babel({
presets: ['@babel/preset-env'],
plugins: ['@babel/plugin-transform-runtime'],
...babelSettings,
exclude: ['node_modules/**/*'],
babelHelpers: 'runtime',
}),
json()
],
},
]
20 changes: 12 additions & 8 deletions test/cross-browser-testing/test-cross-browser.js
Original file line number Diff line number Diff line change
@@ -1,8 +1,12 @@
describe('test browserstack integration', function() {
it('should pass', function() {
true.should.equal(true);
});
it('should not pass on older browsers', function() {
'foo-bar'.replaceAll('o', 0).should.equal('f00-bar');
});
});
// import ms from 'ms';
// import lunchtime from './lunchtime.js';
// import millisecondsUntil from './millisecondsUntil.js';

window.testString = function (str) {
let abc = 'abc'
console.log(`hellothere${{abc}}`)
return str.replaceAll("a", "b");

// const millisecondsUntilLunchTime = millisecondsUntil(lunchtime(hours, minutes));
// return ms(millisecondsUntilLunchTime, { long: true });
};
1 change: 0 additions & 1 deletion test/karma.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@ const { DEBUG } = process.env;

const files = [
'lib/geomock.js',
'config.js',
'../dist/mparticle.js',
'test-bundle.js',
];
Expand Down

0 comments on commit 30b4108

Please sign in to comment.