mirror of
https://github.com/tauri-apps/tauri.git
synced 2024-12-19 16:41:34 +03:00
6a21965ff3
* chore: add prettier for js/ts formatting * fix lint-staged to object * test commit * format all * lock file bump * eslint extends prettier This will let us skip rules in eslint that prettier can control. Prettier for styles, eslint for code errors. * add prettier config * roll back to what we had with eslint settings * skip mutation observer * add prettier typescript eslint * run prettier in lint workflow * format:check script * turn off space before function in eslint it is fighting with prettier * fix dir in workflow * remove semis * add api to eslint * shift eslint ignore comment after prettier format * ignore errors that currently exist * build:typevalidators * replace was broken on typevalidator build * try pushing up error * format * try removing working dir from eslint workflow * try node 12 * fix indent in action * bump eslint * fix supposeded error and try another * try breaking eslint * try building in action * adjust action paths again * need dot * remove build * fix(tauri.js/eslint): escape glob * * fix(tauri.js): ignore lint error * Create prettier-taurijs.md Co-authored-by: Noah Klayman <noahklayman@gmail.com>
87 lines
2.2 KiB
JavaScript
87 lines
2.2 KiB
JavaScript
const path = require('path')
|
|
const fixtureSetup = require('../fixtures/app-test-setup')
|
|
const appDir = path.join(fixtureSetup.fixtureDir, 'app')
|
|
const distDir = path.join(appDir, 'dist')
|
|
|
|
const spawn = require('helpers/spawn').spawn
|
|
|
|
function runBuildTest(tauriConfig) {
|
|
fixtureSetup.initJest('app')
|
|
const build = require('api/build')
|
|
return new Promise(async (resolve, reject) => {
|
|
try {
|
|
let success = false
|
|
const { server, responses } = fixtureSetup.startServer(() => {
|
|
success = true
|
|
try {
|
|
process.kill(appPid)
|
|
} catch {}
|
|
// wait for the app process to be killed
|
|
setTimeout(resolve, 2000)
|
|
})
|
|
const result = build(tauriConfig)
|
|
await result.promise
|
|
|
|
const artifactFolder = tauriConfig.ctx.debug ? 'debug' : 'release'
|
|
const artifactPath = path.resolve(
|
|
appDir,
|
|
`src-tauri/target/${artifactFolder}/app`
|
|
)
|
|
|
|
const appPid = spawn(
|
|
process.platform === 'win32'
|
|
? `${artifactPath}.exe`
|
|
: artifactPath.replace(
|
|
`${artifactFolder}/app`,
|
|
`${artifactFolder}/./app`
|
|
),
|
|
[],
|
|
null
|
|
)
|
|
|
|
setTimeout(() => {
|
|
if (!success) {
|
|
server.close(() => {
|
|
try {
|
|
process.kill(appPid)
|
|
} catch {}
|
|
const failedCommands = Object.keys(responses)
|
|
.filter((k) => responses[k] === null)
|
|
.join(', ')
|
|
reject("App didn't reply to " + failedCommands)
|
|
})
|
|
}
|
|
}, 15000)
|
|
} catch (error) {
|
|
reject(error)
|
|
}
|
|
})
|
|
}
|
|
|
|
describe('Tauri Build', () => {
|
|
const build = {
|
|
devPath: distDir,
|
|
distDir: distDir
|
|
}
|
|
|
|
it.each`
|
|
mode | flag
|
|
${'embedded-server'} | ${'debug'}
|
|
${'embedded-server'} | ${'release'}
|
|
${'no-server'} | ${'debug'}
|
|
${'no-server'} | ${'release'}
|
|
`('works with the $mode $flag mode', ({ mode, flag }) => {
|
|
return runBuildTest({
|
|
build,
|
|
ctx: {
|
|
debug: flag === 'debug'
|
|
},
|
|
tauri: {
|
|
embeddedServer: {
|
|
active: mode === 'embedded-server'
|
|
}
|
|
}
|
|
})
|
|
})
|
|
})
|