This repository has been archived by the owner on Jul 8, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbuild.xml
72 lines (60 loc) · 3.06 KB
/
build.xml
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
<?xml version="1.0" encoding="UTF-8"?>
<!-- Set some basic project information and targets -->
<project name="HRPHP Widgets Web API" default="build" basedir=".">
<target name="build"
depends="prepare, phpcs, create-test-db, seed-test-db, phpunit, drop-test-db" />
<property name="db.host" value="127.0.0.1" override="true" />
<property name="db.name" value="widgets-api-test" override="true" />
<property name="db.user" value="root" override="true" />
<property name="db.pass" value="" override="true" />
<property name="db.url" value="mysql:host=${db.host};dbname=${db.name}" override="true" />
<property name="bin.dir" value="${project.basedir}/vendor/bin" override="true" />
<property name="reports.dir" value="${project.basedir}/reports" override="true" />
<fileset dir="${project.basedir}/src/application" id="php.files">
<patternset refid="php"/>
</fileset>
<!-- Create and seed test database -->
<target name="create-test-db" description="Create test database">
<pdo url="mysql:host=${db.host}" encoding="utf8" userId="${db.user}" password="${db.pass}" onerror="abort">
DROP DATABASE IF EXISTS `${db.name}`;
CREATE DATABASE `${db.name}` /*!40100 DEFAULT CHARACTER SET utf8 */;
</pdo>
</target>
<!-- Create and seed test database -->
<target name="seed-test-db" description="Seed test database" depends="create-test-db">
<pdo url="${db.url}" encoding="utf8" userId="${db.user}" password="${db.pass}" onerror="abort">
USE `${db.name}`;
<fileset dir="${project.basedir}/conf">
<include name="db.sql" />
</fileset>
</pdo>
</target>
<!-- Drop test database -->
<target name="drop-test-db" description="Drop test database">
<pdo url="${db.url}" encoding="utf8" userId="${db.user}" password="${db.pass}" onerror="abort">
DROP DATABASE IF EXISTS `${db.name}`;
</pdo>
</target>
<!-- Clean up from previous builds -->
<target name="clean" description="Cleanup build artifacts">
<delete dir="${reports.dir}/coverage" />
<delete dir="${reports.dir}/logs" />
</target>
<!-- Prepare for the new build -->
<target name="prepare" description="Prepare for build" depends="clean">
<mkdir dir="${reports.dir}/coverage" />
<mkdir dir="${reports.dir}/logs" />
</target>
<!-- PHP Code Sniffer -->
<target name="phpcs" description="Check code style with PHP Code Sniffer">
<echo msg="Checking code against PSR2 standard..." />
<exec command="${bin.dir}/phpcs --standard=PSR2 --extensions=php --ignore=*/config/* src > ${reports.dir}/logs/phpcs.log"
checkreturn="true" />
</target>
<!-- PHPUnit -->
<target name="phpunit" description="Run unit tests with PHPUnit" depends="seed-test-db">
<echo msg="Running tests in test suite..." />
<exec command="${bin.dir}/phpunit --coverage-clover ${reports.dir}/coverage/clover.xml tests"
checkreturn="true" />
</target>
</project>