Tools: Moved testing under "npm run test" and clean-up no longer used shell scripts

pull/2549/head
Laurent Cozic 2020-02-21 12:15:06 +00:00
parent 2d1aa27955
commit b4b424bf8a
12 changed files with 39 additions and 39 deletions

View File

@ -66,7 +66,7 @@ script:
# and that would break the desktop release. # and that would break the desktop release.
if [ "$TRAVIS_PULL_REQUEST" != "false" ]; then if [ "$TRAVIS_PULL_REQUEST" != "false" ]; then
cd CliClient cd CliClient
./run_test.sh npm run test
testResult=$? testResult=$?
if [ $testResult -ne 0 ]; then if [ $testResult -ne 0 ]; then
exit $testResult exit $testResult

View File

@ -75,8 +75,6 @@ If `yarn dist` fails, it may need administrative rights.
If you get an `error MSB8020: The build tools for v140 cannot be found.` try to run with a different toolset version, eg `npm install --toolset=v141` (See [here](https://github.com/mapbox/node-sqlite3/issues/1124) for more info). If you get an `error MSB8020: The build tools for v140 cannot be found.` try to run with a different toolset version, eg `npm install --toolset=v141` (See [here](https://github.com/mapbox/node-sqlite3/issues/1124) for more info).
The [building\_win32\_tips on this page](./readme/building_win32_tips.md) might be helpful.
## Other issues ## Other issues
> The application window doesn't open or is white > The application window doesn't open or is white

View File

@ -61,19 +61,19 @@ npm install
To run all the test units: To run all the test units:
```sh ```sh
./run_test.sh npm run test
``` ```
To run just one particular file: To run just one particular file:
```sh ```sh
./run_test.sh markdownUtils # Don't add the .js extension npm run test -- --filter=markdownUtils # Don't add the .js extension
``` ```
To filter tests: To filter tests. For example, to run all the test units that contain "should handle conflict" in their description:
```sh ```sh
./run_test.sh "should handle conflict" # Will run all the test units that contain "should handle conflict" in their description npm run test -- --filter="should handle conflict"
``` ```
If you get the error `Cannot find module '/joplin/CliClient/node_modules/sqlite3/lib/binding/node-v79-darwin-x64/node_sqlite3.node'`, you may need to run `npm rebuild`. If you get the error `Cannot find module '/joplin/CliClient/node_modules/sqlite3/lib/binding/node-v79-darwin-x64/node_sqlite3.node'`, you may need to run `npm rebuild`.

View File

@ -1,3 +1,3 @@
#!/bin/bash #!/bin/bash
set -e set -e
./build.sh && NODE_PATH=build node build/build-doc.js npm run build && NODE_PATH=build node build/build-doc.js

View File

@ -1,3 +1,3 @@
#!/bin/bash #!/bin/bash
set -e set -e
./build.sh && NODE_PATH="build/" node build/cli-integration-tests.js npm run build && NODE_PATH="build/" node build/cli-integration-tests.js

View File

@ -1,3 +1,3 @@
#!/bin/bash #!/bin/bash
set -e set -e
./build.sh && NODE_PATH="build/" node build/fuzzing.js npm run build && NODE_PATH="build/" node build/fuzzing.js

View File

@ -5,10 +5,9 @@ const tasks = {
copyLib: require('../Tools/gulp/tasks/copyLib'), copyLib: require('../Tools/gulp/tasks/copyLib'),
}; };
const buildDir = `${__dirname}/build`;
tasks.build = { tasks.build = {
fn: async () => { fn: async () => {
const buildDir = `${__dirname}/build`;
await utils.copyDir(`${__dirname}/app`, buildDir, { await utils.copyDir(`${__dirname}/app`, buildDir, {
excluded: ['node_modules'], excluded: ['node_modules'],
}); });
@ -19,4 +18,23 @@ tasks.build = {
}, },
}; };
tasks.buildTests = {
fn: async () => {
const testBuildDir = `${__dirname}/tests-build`;
await utils.copyDir(`${__dirname}/tests`, testBuildDir, {
excluded: [
'lib/',
'locales/',
'node_modules/',
],
});
await utils.copyDir(`${__dirname}/../ReactNativeClient/lib`, `${testBuildDir}/lib`);
await utils.copyDir(`${__dirname}/../ReactNativeClient/locales`, `${testBuildDir}/locales`);
await fs.mkdirp(`${testBuildDir}/data`);
},
};
gulp.task('build', tasks.build.fn); gulp.task('build', tasks.build.fn);
gulp.task('buildTests', tasks.buildTests.fn);

View File

@ -4,6 +4,7 @@
"license": "MIT", "license": "MIT",
"author": "Laurent Cozic", "author": "Laurent Cozic",
"scripts": { "scripts": {
"test": "gulp buildTests -L && jasmine --config=tests/support/jasmine.json",
"postinstall": "patch-package && npm run build", "postinstall": "patch-package && npm run build",
"build": "gulp build", "build": "gulp build",
"start": "gulp build -L && node 'build/main.js' --profile ~/Temp/TestNotes2 --stack-trace-enabled --log-level debug --env dev" "start": "gulp build -L && node 'build/main.js' --profile ~/Temp/TestNotes2 --stack-trace-enabled --log-level debug --env dev"

View File

@ -1,24 +0,0 @@
#!/bin/bash
START_DIR="$(pwd)"
ROOT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
BUILD_DIR="$ROOT_DIR/tests-build"
FILTER="$1"
rsync -a --delete --exclude "lib/" --exclude "locales/" --exclude "node_modules/" "$ROOT_DIR/tests/" "$BUILD_DIR/"
rsync -a --delete "$ROOT_DIR/../ReactNativeClient/lib/" "$BUILD_DIR/lib/"
rsync -a --delete "$ROOT_DIR/../ReactNativeClient/locales/" "$BUILD_DIR/locales/"
mkdir -p "$BUILD_DIR/data"
function finish {
cd "$START_DIR"
}
trap finish EXIT
cd "$ROOT_DIR"
if [[ $FILTER != "" ]]; then
npx jasmine --config=tests/support/jasmine.json --filter="$FILTER"
else
npx jasmine --config=tests/support/jasmine.json
fi

View File

@ -7,7 +7,9 @@ echo "---------------------------------------------------"
echo "Rebuild API doc..." echo "Rebuild API doc..."
echo "---------------------------------------------------" echo "---------------------------------------------------"
# TODO: When the apidoc command fails, it copy the failure in api.md, but shouldn't be doing that # TODO: When the apidoc command fails, it copy the failure in api.md, but shouldn't be doing that
"$ROOT_DIR/../CliClient/run.sh" apidoc > "$ROOT_DIR/../readme/api.md" cd "$ROOT_DIR/../CliClient"
npm run start -- apidoc > "$ROOT_DIR/../readme/api.md"
cd "$ROOT_DIR"
echo "---------------------------------------------------" echo "---------------------------------------------------"
echo "$ROOT_DIR/update-readme-download.js..." echo "$ROOT_DIR/update-readme-download.js..."

View File

@ -56,8 +56,9 @@ async function main() {
console.info(`Building ${newVersion}...`); console.info(`Building ${newVersion}...`);
const newTag = `cli-${newVersion}`; const newTag = `cli-${newVersion}`;
await execCommand('git pull');
await execCommand('touch app/main.js'); await execCommand('touch app/main.js');
await execCommand('bash build.sh'); await execCommand('npm run build');
await execCommand('cp package.json build/'); await execCommand('cp package.json build/');
await execCommand('cp ../README.md build/'); await execCommand('cp ../README.md build/');
@ -74,7 +75,6 @@ async function main() {
const defaultEditor = await execCommand('echo $EDITOR'); const defaultEditor = await execCommand('echo $EDITOR');
const finalCmds = [ const finalCmds = [
'git pull',
'git add -A', 'git add -A',
`git commit -m "CLI ${newVersion}"`, `git commit -m "CLI ${newVersion}"`,
`git tag "cli-${newVersion}"`, `git tag "cli-${newVersion}"`,

View File

@ -1,3 +1,8 @@
* * *
**IMPORTANT: The build system has been changed since this document was written, thus it contains outdated information. It is kept for now as it may still contain some tips on how to get things working.**
* * *
## Building Joplin on Windows ## Building Joplin on Windows