mirror of
https://github.com/nuxt/nuxt.git
synced 2024-11-12 00:53:55 +00:00
88c9bae57b
* feat: add tests to check for changed files Make sure that if we are building or generating only files in buildDir and generate.dir are changed. If files in another location would also be changed due to a new config option, those locations should be guarded in lib/common/options so you cant set them lower then rootDir or srcDir. * fix running tests inBand use simpler path comparisons * add debug logs for ci use process.hrtime for waitFor test * add debug logs for ci use process.hrtime for waitFor test * use writeFileSync should probably help * use forEach instead of map when not returning a value update waitFor test to compare values with jest * fix appeveyor * use lower limit than delay in waitFor test revert isAppveyor export
75 lines
2.3 KiB
JavaScript
75 lines
2.3 KiB
JavaScript
import path from 'path'
|
|
import fs from 'fs'
|
|
import klawSync from 'klaw-sync'
|
|
|
|
import _getPort from 'get-port'
|
|
import { defaultsDeep, find } from 'lodash'
|
|
import _rp from 'request-promise-native'
|
|
import pkg from '../../package.json'
|
|
import _Nuxt from '../../lib/index.js'
|
|
|
|
export const rp = _rp
|
|
export const getPort = _getPort
|
|
export const version = pkg.version
|
|
|
|
export const Nuxt = _Nuxt.Nuxt
|
|
export const Utils = _Nuxt.Utils
|
|
export const Options = _Nuxt.Options
|
|
export const Builder = _Nuxt.Builder
|
|
export const Generator = _Nuxt.Generator
|
|
|
|
export const loadFixture = async function (fixture, overrides) {
|
|
const rootDir = path.resolve(__dirname, '..', 'fixtures', fixture)
|
|
const configFile = path.resolve(rootDir, 'nuxt.config.js')
|
|
|
|
const config = fs.existsSync(configFile) ? (await import(`../fixtures/${fixture}/nuxt.config`)).default : {}
|
|
|
|
config.rootDir = rootDir
|
|
config.dev = false
|
|
|
|
return defaultsDeep({}, overrides, config)
|
|
}
|
|
|
|
/**
|
|
* Prepare an object to pass to the createSportsSelectionView function
|
|
* @param {Function} condition return true to stop the waiting
|
|
* @param {Number} duration seconds totally wait
|
|
* @param {Number} interval milliseconds interval to check the condition
|
|
*
|
|
* @returns {Boolean} true: timeout, false: condition becomes true within total time
|
|
*/
|
|
export const waitUntil = async function waitUntil(condition, duration = 20, interval = 250) {
|
|
let iterator = 0
|
|
const steps = Math.floor(duration * 1000 / interval)
|
|
|
|
while (!condition() && iterator < steps) {
|
|
await Utils.waitFor(interval)
|
|
iterator++
|
|
}
|
|
|
|
if (iterator === steps) {
|
|
return true
|
|
}
|
|
return false
|
|
}
|
|
|
|
export const listPaths = function listPaths(dir, pathsBefore = [], options = {}) {
|
|
if (Array.isArray(pathsBefore) && pathsBefore.length) {
|
|
// only return files that didn't exist before building
|
|
// and files that have been changed
|
|
options.filter = (item) => {
|
|
const foundItem = find(pathsBefore, (itemBefore) => {
|
|
return item.path === itemBefore.path
|
|
})
|
|
return typeof foundItem === 'undefined' ||
|
|
item.stats.mtimeMs !== foundItem.stats.mtimeMs
|
|
}
|
|
}
|
|
|
|
return klawSync(dir, options)
|
|
}
|
|
|
|
export const equalOrStartsWith = function equalOrStartsWith(string1, string2) {
|
|
return string1 === string2 || string2.startsWith(string1)
|
|
}
|