mirror of
https://github.com/twbs/bootstrap.git
synced 2024-12-01 13:24:25 +01:00
e202996a2b
* @babel/cli ^7.14.8 → ^7.15.5 * @babel/core ^7.14.8 → ^7.15.4 * @babel/preset-env ^7.14.8 → ^7.15.6 * @rollup/plugin-commonjs ^19.0.1 → ^20.0.0 * @rollup/plugin-node-resolve ^13.0.2 → ^13.0.4 * autoprefixer ^10.3.1 → ^10.3.4 * clean-css-cli ^5.3.0 → ^5.3.3 * eslint ^7.31.0 → ^7.32.0 * eslint-config-xo ^0.37.0 → ^0.38.0 * eslint-plugin-import ^2.23.4 → ^2.24.2 * eslint-plugin-unicorn ^34.0.1 → ^36.0.0 * hugo-bin ^0.74.0 → ^0.76.1 * qunit ^2.16.0 → ^2.17.1 * postcss ^8.3.5 → ^8.3.6 * rollup ^2.53.3 → ^2.56.3 * vnu-jar 21.6.11 → 21.9.2
61 lines
2.1 KiB
JavaScript
61 lines
2.1 KiB
JavaScript
#!/usr/bin/env node
|
|
|
|
/*!
|
|
* Script to run vnu-jar if Java is available.
|
|
* Copyright 2017-2021 The Bootstrap Authors
|
|
* Copyright 2017-2021 Twitter, Inc.
|
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
|
|
*/
|
|
|
|
'use strict'
|
|
|
|
const { execFile, spawn } = require('child_process')
|
|
const vnu = require('vnu-jar')
|
|
|
|
execFile('java', ['-version'], (error, stdout, stderr) => {
|
|
if (error) {
|
|
console.error('Skipping vnu-jar test; Java is missing.')
|
|
return
|
|
}
|
|
|
|
const is32bitJava = !/64-Bit/.test(stderr)
|
|
|
|
// vnu-jar accepts multiple ignores joined with a `|`.
|
|
// Also note that the ignores are string regular expressions.
|
|
const ignores = [
|
|
// "autocomplete" is included in <button> and checkboxes and radio <input>s due to
|
|
// Firefox's non-standard autocomplete behavior - see https://bugzilla.mozilla.org/show_bug.cgi?id=654072
|
|
'Attribute “autocomplete” is only allowed when the input type is.*',
|
|
'Attribute “autocomplete” not allowed on element “button” at this point.',
|
|
// IE11 doesn't recognise <main> / give the element an implicit "main" landmark.
|
|
// Explicit role="main" is redundant for other modern browsers, but still valid.
|
|
'The “main” role is unnecessary for element “main”.',
|
|
// Per https://www.w3.org/TR/html-aria/#docconformance having "aria-disabled" on a link is
|
|
// NOT RECOMMENDED, but it's still valid - we explain in the docs that it's not ideal,
|
|
// and offer more robust alternatives, but also need to show a less-than-ideal example
|
|
'An “aria-disabled” attribute whose value is “true” should not be specified on an “a” element that has an “href” attribute.'
|
|
].join('|')
|
|
|
|
const args = [
|
|
'-jar',
|
|
`"${vnu}"`,
|
|
'--asciiquotes',
|
|
'--skip-non-html',
|
|
'--Werror',
|
|
`--filterpattern "${ignores}"`,
|
|
'_site/',
|
|
'js/tests/'
|
|
]
|
|
|
|
// For the 32-bit Java we need to pass `-Xss512k`
|
|
if (is32bitJava) {
|
|
args.splice(0, 0, '-Xss512k')
|
|
}
|
|
|
|
return spawn('java', args, {
|
|
shell: true,
|
|
stdio: 'inherit'
|
|
})
|
|
.on('exit', process.exit)
|
|
})
|