-
Notifications
You must be signed in to change notification settings - Fork 5
How to update a module to version 2
in the beginning you need to decide if the package needs a distributable version. This might not be neccessary.
if you choose so, add folders in conf with the names build and dist. move the entry.js and webpack.js to the build folder and create new ones in the dist folder. Use maybe guide4you-module-urlapi as a template. Take care to update all paths.
rm -rf node_modules/
in the background
add guide4you
, jquery
, openlayers
and any guide4you
modules as peerDependencies
and devDependencies
, remove them as dependencies
"devDependencies": {
"guide4you": "2.0.*",
"jquery": "3.2.1",
"openlayers": "github:KlausBenndorf/ol3#g4u3_v4.1.0"
}
"peerDependencies": {
"guide4you": "2.0.*",
"jquery": "3.2.1",
"openlayers": "github:KlausBenndorf/ol3#g4u3_v4.1.0"
}
move guide4you-proxy
to devDependencies
update used versions in dependencies
and devDependencies
add http-server
to devDependencies
devDependencies
should look something like this:
"devDependencies": {
"concurrently": "^3.4.0",
"copy-webpack-plugin": "^4.0.1",
"esdoc": "0.5.2",
"guide4you": "2.0.*",
"guide4you-builder": "2.0.*",
"guide4you-proxy": "github:KlausBenndorf/guide4you-proxy#v1.0.0",
"html-webpack-include-assets-plugin": "0.0.5",
"html-webpack-plugin": "2.28.0",
"http-server": "^0.10.0",
"jquery": "3.2.1",
"mocha": "3.4.2",
"openlayers": "github:KlausBenndorf/ol3#g4u3_v4.1.0",
"phantomjs-prebuilt": "2.1.14",
"selenium-webdriver": "3.4.0",
"standard": "10.0.2",
"wait-on": "2.0.2"
}
npm install
in the background (after rm -rf
completed)
update scripts to something like this (take care of proper paths):
with distributable version:
"scripts": {
"dist": "g4u-build -m dist -c conf/dist",
"linkRepos": "g4u-link guide4you",
"unlinkRepos": "g4u-unlink guide4you",
"build": "g4u-build -m prod -c",
"dev": "g4u-build -m dev -c",
"prepublishOnly": "npm test && git add dist/ && git commit --amend",
"lint": "eslint src/ tests/",
"buildTests": "concurrently \"g4u-buildTests\" \"npm run dist\"",
"runTests": "wait-on -l http-get://localhost:8089 && mocha build/tests/*",
"test": "npm run lint && npm run buildTests && concurrently --kill-others --success first \"http-server ./ -p 8089 -s\" \"npm run runTests\" && echo \"Tests completed successfully\"",
"doc": "esdoc -c esdoc.json"
}
without distributable version:
"scripts": {
"linkRepos": "g4u-link guide4you",
"unlinkRepos": "g4u-unlink guide4you",
"build": "g4u-build -m prod -c",
"dev": "g4u-build -m dev -c",
"prepublishOnly": "npm test", // <--
"lint": "eslint src/ tests/",
"buildTests": "concurrently \"g4u-buildTests\" \"npm run build conf/\"", // <--
"runTests": "wait-on -l http-get://localhost:8089 && mocha build/tests/*",
"test": "npm run lint && npm run buildTests && concurrently --kill-others --success first \"http-server ./ -p 8089 -s\" \"npm run runTests\" && echo \"Tests completed successfully\"",
"doc": "esdoc -c esdoc.json"
}
the following requires are needed:
const mustacheEvalLoader = require('guide4you-builder/mustache-eval-loader')
const HtmlWebpackPlugin = require('html-webpack-plugin')
const HtmlWebpackIncludeAssetsPlugin = require('html-webpack-include-assets-plugin')
const CopyWebpackPlugin = require('copy-webpack-plugin')
the mustacheEvalLoader
is now configured like this:
mustacheEvalLoader.setTemplateVars({
pageTitle: '...',
etc
})
the module.export
's entry property now has a property named g4u
- that's what used to be called lib/g4u.js
the alias for the the less configuration that used to be lessConfig.less
is now called lessConfig
new plugins:
new CopyWebpackPlugin([
{ from: 'node_modules/jquery/dist/jquery.min.js', to: 'js/jquery.min.js' },
{ from: 'node_modules/openlayers/dist/ol.js', to: 'js/ol.js' }
]),
new HtmlWebpackIncludeAssetsPlugin({
assets: [
'js/jquery.min.js',
'js/ol.js'
],
append: false
})
install them with -D
Replace
import { createG4UInternal } from 'guide4you/src/main'
by
import { createMapInternal } from 'guide4you/src/main'
instead of assigning a method createG4U to the window object:
export function createMap ...
and
export * from 'guide4you/src/exports'
Note that using modules has also changed with most recent version of guide4you. In order to have access to someModule
please use something along the lines of
registerModule(new someModule())
export function createMap (target, clientConf = defaultClientConf, layerConf = defaultLayerConf) {
return createMapInternal(target, clientConf, layerConf)
}
remove everything related to the tests folder from the .gitignore
.
move contents of selenium/
and unit-tests/
to the parent folder. If you want to use unit-tests, just create *_spec.js
files in the tests folder and don't use selenium but a unit test framework (maybe chai). These files will be run with mocha.
- make sure that all loaders have a
-loader
postfix. - the
mustache-eval-loader
andto-json-file-loader
can be used without theguide4you-builder
prefix but inside of less files don't forget to put a~
in front of their name. - import paths relative to the base folder can be used like this:
src/something.js
.
use g4u.createMap
instead of createG4U
remove all local repositories from the linkRepos script with rights to create symlinks
npm run dev conf/ (or npm run dev conf/build)
npm test
npm dist (if configured)
npm run build conf (or npm run build conf/build)
update to guide4you version 2.1.*
use the registerModules function in all entry.js files instead of the modules: [] array.
See https://github.com/KlausBenndorf/guide4you-module-urlapi/blob/master/conf/build/entry.js
Use the version script hook of guide4you to run the tests. See https://github.com/KlausBenndorf/guide4you-module-urlapi/blob/master/package.json#L50
You can now integrate tests of other guide4you modules into your own tests. See https://github.com/KlausBenndorf/guide4you-module-urlapi/blob/master/package.json#L51 . You might need to adjust you client config to integrate the tested controls.
git add all but the files in the dist folders && git commit && git checkout . && npm version minor && npm publish