Update makefile
This commit is contained in:
165
Makefile
165
Makefile
@@ -1,46 +1,6 @@
|
|||||||
# This file is licensed under the Affero General Public License version 3 or
|
|
||||||
# later. See the COPYING file.
|
|
||||||
# @author Bernhard Posselt <dev@bernhard-posselt.com>
|
|
||||||
# @copyright Bernhard Posselt 2012, 2014
|
|
||||||
|
|
||||||
# Generic Makefile for building and packaging an ownCloud app which uses npm and
|
|
||||||
# Composer.
|
|
||||||
#
|
|
||||||
# Dependencies:
|
|
||||||
# * make
|
|
||||||
# * which
|
|
||||||
# * curl: used if phpunit and composer are not installed to fetch them from the web
|
|
||||||
# * tar: for building the archive
|
|
||||||
# * npm: for building and testing everything JS
|
|
||||||
#
|
|
||||||
# If no composer.json is in the app root directory, the Composer step
|
|
||||||
# will be skipped. The same goes for the package.json which can be located in
|
|
||||||
# the app root or the js/ directory.
|
|
||||||
#
|
|
||||||
# The npm command by launches the npm build script:
|
|
||||||
#
|
|
||||||
# npm run build
|
|
||||||
#
|
|
||||||
# The npm test command launches the npm test script:
|
|
||||||
#
|
|
||||||
# npm run test
|
|
||||||
#
|
|
||||||
# The idea behind this is to be completely testing and build tool agnostic. All
|
|
||||||
# build tools and additional package managers should be installed locally in
|
|
||||||
# your project, since this won't pollute people's global namespace.
|
|
||||||
#
|
|
||||||
# The following npm scripts in your package.json install and update the bower
|
|
||||||
# and npm dependencies and use gulp as build system (notice how everything is
|
|
||||||
# run from the node_modules folder):
|
|
||||||
#
|
|
||||||
# "scripts": {
|
|
||||||
# "test": "node node_modules/gulp-cli/bin/gulp.js karma",
|
|
||||||
# "prebuild": "npm install && node_modules/bower/bin/bower install && node_modules/bower/bin/bower update",
|
|
||||||
# "build": "node node_modules/gulp-cli/bin/gulp.js"
|
|
||||||
# },
|
|
||||||
|
|
||||||
app_name=$(notdir $(CURDIR))
|
app_name=$(notdir $(CURDIR))
|
||||||
build_tools_directory=$(CURDIR)/build/tools
|
build_tools_directory=$(CURDIR)/build/tools
|
||||||
|
build_dir=$(CURDIR)/build/artifacts
|
||||||
source_build_directory=$(CURDIR)/build/artifacts/source
|
source_build_directory=$(CURDIR)/build/artifacts/source
|
||||||
source_package_name=$(source_build_directory)/$(app_name)
|
source_package_name=$(source_build_directory)/$(app_name)
|
||||||
appstore_build_directory=$(CURDIR)/build/artifacts/appstore
|
appstore_build_directory=$(CURDIR)/build/artifacts/appstore
|
||||||
@@ -48,91 +8,37 @@ appstore_package_name=$(appstore_build_directory)/$(app_name)
|
|||||||
npm=$(shell which npm 2> /dev/null)
|
npm=$(shell which npm 2> /dev/null)
|
||||||
composer=$(shell which composer 2> /dev/null)
|
composer=$(shell which composer 2> /dev/null)
|
||||||
|
|
||||||
all: build
|
sign_dir=$(build_dir)/sign
|
||||||
|
cert_dir=$(HOME)/.nextcloud/certificates
|
||||||
|
|
||||||
# Fetches the PHP and JS dependencies and compiles the JS. If no composer.json
|
|
||||||
# is present, the composer step is skipped, if no package.json or js/package.json
|
|
||||||
# is present, the npm step is skipped
|
|
||||||
.PHONY: build
|
|
||||||
build:
|
|
||||||
ifneq (,$(wildcard $(CURDIR)/composer.json))
|
|
||||||
make composer
|
|
||||||
endif
|
|
||||||
ifneq (,$(wildcard $(CURDIR)/package.json))
|
|
||||||
make npm
|
|
||||||
endif
|
|
||||||
ifneq (,$(wildcard $(CURDIR)/js/package.json))
|
|
||||||
make npm
|
|
||||||
endif
|
|
||||||
|
|
||||||
# Installs and updates the composer dependencies. If composer is not installed
|
all: appstore
|
||||||
# a copy is fetched from the web
|
|
||||||
.PHONY: composer
|
|
||||||
composer:
|
|
||||||
ifeq (, $(composer))
|
|
||||||
@echo "No composer command available, downloading a copy from the web"
|
|
||||||
mkdir -p $(build_tools_directory)
|
|
||||||
curl -sS https://getcomposer.org/installer | php
|
|
||||||
mv composer.phar $(build_tools_directory)
|
|
||||||
php $(build_tools_directory)/composer.phar install --prefer-dist
|
|
||||||
php $(build_tools_directory)/composer.phar update --prefer-dist
|
|
||||||
else
|
|
||||||
composer install --prefer-dist
|
|
||||||
composer update --prefer-dist
|
|
||||||
endif
|
|
||||||
|
|
||||||
# Installs npm dependencies
|
clean-build:
|
||||||
.PHONY: npm
|
rm -rf $(build_dir)
|
||||||
npm:
|
|
||||||
ifeq (,$(wildcard $(CURDIR)/package.json))
|
|
||||||
cd js && $(npm) run build
|
|
||||||
else
|
|
||||||
npm run build
|
|
||||||
endif
|
|
||||||
|
|
||||||
# Removes the appstore build
|
clean-dist:
|
||||||
.PHONY: clean
|
|
||||||
clean:
|
|
||||||
rm -rf ./build
|
|
||||||
|
|
||||||
# Same as clean but also removes dependencies installed by composer, bower and
|
|
||||||
# npm
|
|
||||||
.PHONY: distclean
|
|
||||||
distclean: clean
|
|
||||||
rm -rf vendor
|
|
||||||
rm -rf node_modules
|
|
||||||
rm -rf js/vendor
|
|
||||||
rm -rf js/node_modules
|
rm -rf js/node_modules
|
||||||
|
rm -rf js/vendor
|
||||||
|
|
||||||
# Builds the source and appstore package
|
install-npm-deps-dev:
|
||||||
.PHONY: dist
|
cd js && npm install --deps
|
||||||
dist:
|
cd js && bower install
|
||||||
make source
|
|
||||||
make appstore
|
|
||||||
|
|
||||||
# Builds the source package
|
install-deps:
|
||||||
.PHONY: source
|
cd js && npm install --deps
|
||||||
source:
|
cd js && bower install
|
||||||
make build
|
|
||||||
make test
|
|
||||||
rm -rf $(source_build_directory)
|
|
||||||
mkdir -p $(source_build_directory)
|
|
||||||
tar cvzf $(source_package_name).tar.gz ../$(app_name) \
|
|
||||||
--exclude-vcs \
|
|
||||||
--exclude="../$(app_name)/build" \
|
|
||||||
--exclude="../$(app_name)/js/node_modules" \
|
|
||||||
--exclude="../$(app_name)/*.log" \
|
|
||||||
--exclude="../$(app_name)/js/*.log" \
|
|
||||||
|
|
||||||
# Builds the source package for the app store, ignores php and js tests
|
build: build-js
|
||||||
.PHONY: appstore
|
|
||||||
appstore:
|
build-js:
|
||||||
make build
|
$(MAKE) -C js build
|
||||||
make test
|
|
||||||
|
# appstore: clean install-deps
|
||||||
|
appstore: clean-build build
|
||||||
rm -rf $(appstore_build_directory)
|
rm -rf $(appstore_build_directory)
|
||||||
mkdir -p $(appstore_build_directory)
|
mkdir -p $(appstore_build_directory)
|
||||||
tar cvzf $(appstore_package_name).tar.gz ../$(app_name) \
|
tar cvzf $(appstore_package_name).tar.gz \
|
||||||
--exclude-vcs \
|
|
||||||
--exclude="../$(app_name)/build" \
|
--exclude="../$(app_name)/build" \
|
||||||
--exclude="../$(app_name)/tests" \
|
--exclude="../$(app_name)/tests" \
|
||||||
--exclude="../$(app_name)/Makefile" \
|
--exclude="../$(app_name)/Makefile" \
|
||||||
@@ -153,26 +59,27 @@ appstore:
|
|||||||
--exclude="../$(app_name)/protractor\.*" \
|
--exclude="../$(app_name)/protractor\.*" \
|
||||||
--exclude="../$(app_name)/.*" \
|
--exclude="../$(app_name)/.*" \
|
||||||
--exclude="../$(app_name)/js/.*" \
|
--exclude="../$(app_name)/js/.*" \
|
||||||
|
--exclude-vcs \
|
||||||
|
../$(app_name)
|
||||||
|
|
||||||
|
|
||||||
|
@if [ -f $(cert_dir)/$(app_name).key ]; then \
|
||||||
|
echo "Signing package…"; \
|
||||||
|
openssl dgst -sha512 -sign $(cert_dir)/$(app_name).key $(build_dir)/$(app_name).tar.gz | openssl base64; \
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo $(appstore_package_name).tar.gz
|
||||||
|
|
||||||
|
|
||||||
# Command for running JS and PHP tests. Works for package.json files in the js/
|
|
||||||
# and root directory. If phpunit is not installed systemwide, a copy is fetched
|
|
||||||
# from the internet
|
|
||||||
.PHONY: test
|
|
||||||
test:
|
test:
|
||||||
ifneq (,$(wildcard $(CURDIR)/js/package.json))
|
|
||||||
cd js && $(npm) run test
|
cd js && $(npm) run test
|
||||||
endif
|
|
||||||
ifneq (,$(wildcard $(CURDIR)/package.json))
|
|
||||||
$(npm) run test
|
|
||||||
endif
|
|
||||||
ifeq (, $(shell which phpunit 2> /dev/null))
|
ifeq (, $(shell which phpunit 2> /dev/null))
|
||||||
@echo "No phpunit command available, downloading a copy from the web"
|
@echo "No phpunit command available, downloading a copy from the web"
|
||||||
mkdir -p $(build_tools_directory)
|
mkdir -p $(build_tools_directory)
|
||||||
curl -sSL https://phar.phpunit.de/phpunit.phar -o $(build_tools_directory)/phpunit.phar
|
curl -sSL https://phar.phpunit.de/phpunit.phar -o $(build_tools_directory)/phpunit.phar
|
||||||
php $(build_tools_directory)/phpunit.phar -c phpunit.xml --coverage-clover build/php-unit.clover
|
php $(build_tools_directory)/phpunit.phar -c phpunit.xml --coverage-clover build/php-unit.clover
|
||||||
php $(build_tools_directory)/phpunit.phar -c phpunit.integration.xml --coverage-clover build/php-unit.clover
|
php $(build_tools_directory)/phpunit.phar -c phpunit.integration.xml --coverage-clover build/php-integration.clover
|
||||||
|
|
||||||
else
|
else
|
||||||
phpunit -c phpunit.xml --coverage-clover build/php-unit.coverage.xml
|
phpunit -c phpunit.xml --coverage-clover build/php-unit.clover
|
||||||
phpunit -c phpunit.integration.xml --coverage-clover build/php-unit.integration.coverage.xml
|
phpunit -c phpunit.integration.xml --coverage-clover build/php-unit.clover
|
||||||
endif
|
endif
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
default:
|
build:
|
||||||
grunt build
|
grunt build
|
||||||
|
|
||||||
watch:
|
watch:
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
{
|
{
|
||||||
"name": "ownCloud Deck",
|
"name": "deck",
|
||||||
"version": "0.0.1",
|
"version": "0.0.1",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"angular": "~1.6.1",
|
"angular": "~1.6.1",
|
||||||
|
|||||||
@@ -9,11 +9,11 @@
|
|||||||
"url": "git@github.com:juliushaertl/deck.git"
|
"url": "git@github.com:juliushaertl/deck.git"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"karma": "^1.1.1"
|
"karma": "^1.1.1",
|
||||||
|
"bower": "*",
|
||||||
|
"grunt": "*"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"bower": "*",
|
|
||||||
"grunt": "*",
|
|
||||||
"grunt-cli": "*",
|
"grunt-cli": "*",
|
||||||
"grunt-contrib-concat": "*",
|
"grunt-contrib-concat": "*",
|
||||||
"grunt-contrib-jshint": "*",
|
"grunt-contrib-jshint": "*",
|
||||||
|
|||||||
Reference in New Issue
Block a user