-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
109 lines (70 loc) · 3.16 KB
/
Makefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
# User rules
# The first rule is the default rule, when invoking "make" without argument...
# Build every buildable things
all: install doc browser
# Just install things so it works, basicaly: it just performs a "npm install --production" ATM
install: log/npm-install.log
# Just install things so it works, basicaly: it just performs a "npm install" ATM
dev-install: log/npm-dev-install.log
# Build
build: browser
# Build the browser lib
browser: browser/tea-time.js browser/tea-time.min.js
# This run the JsHint & Mocha BDD test, display it to STDOUT & save it to log/mocha.log and log/jshint.log
test: log/jshint.log log/mocha.log
# This run the JsHint, display it to STDOUT & save it to log/jshint.log
lint: log/jshint.log
# This run the Mocha BDD test, display it to STDOUT & save it to log/mocha.log
unit: log/mocha.log
# This build the doc and README.md
doc: README.md
# This publish to NPM and push to Github, if we are on master branch only
publish: log/npm-publish.log log/github-push.log
# Clean temporary things, or things that can be automatically regenerated
clean: clean-all
# Variables
MOCHA=../node_modules/mocha/bin/mocha
JSHINT=./node_modules/jshint/bin/jshint --verbose
BROWSERIFY=./node_modules/.bin/browserify
UGLIFY=./node_modules/.bin/uglifyjs
# Files rules
# Build the browser lib
browser/tea-time.js: lib/*.js lib/browser-reporters/*.js
${BROWSERIFY} lib/browser.js -s createTeaTime -i xregexp -i mongodb -o browser/tea-time.js
# Build the browser minified lib
browser/tea-time.min.js: browser/tea-time.js
${UGLIFY} browser/tea-time.js -o browser/tea-time.min.js -m
# JsHint STDOUT test
log/jshint.log: log/npm-dev-install.log lib/*.js test/*.js
${JSHINT} lib/*.js test/*.js | tee log/jshint.log ; exit $${PIPESTATUS[0]}
# Mocha BDD STDOUT test
log/mocha.log: log/npm-dev-install.log lib/*.js test/*.js
cd test ; ${MOCHA} *.js -R spec | tee ../log/mocha.log ; exit $${PIPESTATUS[0]}
# README
README.md: documentation.md
cat documentation.md > README.md
# Upgrade version in package.json
log/upgrade-package.log: lib/*.js test/*.js documentation.md
npm version patch -m "Upgrade package.json version to %s" | tee log/upgrade-package.log ; exit $${PIPESTATUS[0]}
# Publish to NPM
log/npm-publish.log: check-if-master-branch log/upgrade-package.log
npm publish | tee log/npm-publish.log ; exit $${PIPESTATUS[0]}
# Push to Github/master
log/github-push.log: lib/*.js test/*.js package.json
#'npm version patch' create the git tag by itself...
#git tag v`cat package.json | grep version | sed -r 's/.*"([0-9.]*)".*/\1/'`
git push origin master --tags | tee log/github-push.log ; exit $${PIPESTATUS[0]}
# NPM install
log/npm-install.log: package.json
npm install --production | tee log/npm-install.log ; exit $${PIPESTATUS[0]}
# NPM install for developpement usage
log/npm-dev-install.log: package.json
npm install | tee log/npm-dev-install.log ; exit $${PIPESTATUS[0]}
# PHONY rules
.PHONY: clean-all check-if-master-branch
# Delete files, mostly log and non-versioned files
clean-all:
rm -rf log/*.log README.md node_modules
# This will fail if we are not on master branch (grep exit 1 if nothing found)
check-if-master-branch:
git branch | grep "^* master$$"