Я создал Дженкинс Джоб. Он работает так, как я его запрограммировал, за исключением тех случаев, когда он имеет ошибки в ошибках, связанных с Lint или PHP, он все равно успешно завершается. Я не уверен, что мне здесь не хватает.
build.xml
<target name="build"depends="build-common,phploc,pdepend,phpmd-ci,phpcs-ci,phpcpd,phpcb" />
<target name="build-clean"depends="clean,build-common,phploc,pdepend,phpmd-ci,phpcs-ci,phpcpd,phpcb" />
<target name="build-dox"depends="build-common,phpdox,phploc,pdepend,phpmd-ci,phpcs-ci,phpcpd,phpcb" />
<target name="build-dox-clean"depends="clean,build-common,phpdox,phploc,pdepend,phpmd-ci,phpcs-ci,phpcpd,phpcb" />
<target name="build-parallel"depends="build-common,tools-parallel" />
<target name="build-parallel-clean"depends="clean,build-common,tools-parallel" />
<target name="build-common" depends="lint,prepare,storage-permissions,composer,phpunit" />
<target name="tools-parallel" description="Run tools in parallel">
<parallel threadCount="2">
<sequential>
<antcall target="pdepend" />
<antcall target="phpcs-ci" />
<antcall target="phpmd-ci" />
</sequential>
<antcall target="phpcb" />
<antcall target="phpcpd" />
<antcall target="phpdox" />
<antcall target="phploc" />
</parallel>
</target>
<target name="clean" depends="clean-build,clean-composer" description="Cleanup build and composer artifacts" />
<target name="clean-build" description="Cleanup build artifacts">
<echo>Cleaning out the build artifacts</echo>
<delete dir="${basedir}/build/api" />
<delete dir="${basedir}/build/code-browser" />
<delete dir="${basedir}/build/coverage" />
<delete dir="${basedir}/build/logs" />
<delete dir="${basedir}/build/pdepend" />
</target>
<target name="clean-composer" description="Cleanup composer artifacts">
<echo>Cleaning out the composer artifacts</echo>
<delete dir="${basedir}/vendor" />
<delete file="${basedir}/composer.lock" />
</target>
<target name="composer" depends="composer-install,composer-update" description="Install or update dependencies" />
<!--// Check to see it the vendor folder already exist, if so, then no reason to run //-->
<target name="composer.check">
<condition property="composer.exist">
<available file="${basedir}/vendor" type="dir" />
</condition>
</target>
<target name="composer-install" depends="composer.check" unless="composer.exist" description="Installing dependencies">
<echo>Installing dependencies</echo>
<exec executable="composer" failonerror="true">
<arg value="install" />
</exec>
</target>
<target name="composer-update" depends="composer.check" if="composer.exist" description="Updating dependencies">
<echo>Updating dependencies</echo>
<exec executable="composer" failonerror="true">
<arg value="update" />
</exec>
</target>
<target name="lint" description="Perform syntax check of sourcecode files">
<apply executable="php" failonerror="false">
<arg value="-l" />
<fileset dir="${basedir}/app">
<include name="**/*.php" />
<modified />
</fileset>
</apply>
</target>
<target name="pdepend" description="Calculate software metrics using PHP_Depend">
<exec executable="pdepend">
<arg value="--jdepend-xml=${basedir}/build/logs/jdepend.xml" />
<arg value="--jdepend-chart=${basedir}/build/pdepend/dependencies.svg" />
<arg value="--overview-pyramid=${basedir}/build/pdepend/overview-pyramid.svg" />
<arg path="${basedir}/app" />
</exec>
</target>
<target name="phpcb" description="Aggregate tool output with PHP_CodeBrowser">
<exec executable="phpcb">
<arg value="--log" />
<arg path="${basedir}/build/logs" />
<arg value="--source" />
<arg path="${basedir}/app" />
<arg value="--output" />
<arg path="${basedir}/build/code-browser" />
</exec>
</target>
<target name="phpcpd" description="Find duplicate code using PHPCPD">
<exec executable="phpcpd">
<arg value="--log-pmd" />
<arg value="${basedir}/build/logs/pmd-cpd.xml" />
<arg path="${basedir}/app" />
</exec>
</target>
<target name="phpcs"description="Find coding standard violations using PHP_CodeSniffer and print human readable output. Intended for usage on the command line before committing.">
<exec executable="phpcs">
<arg value="--standard=${basedir}/build/phpcs.xml" />
<arg path="${basedir}/app" />
</exec>
</target>
<target name="phpcs-ci" description="Find coding standard violations using PHP_CodeSniffer creating a log file for the continuous integration server">
<exec executable="phpcs" output="/dev/null">
<arg value="--report=checkstyle" />
<arg value="--report-file=${basedir}/build/logs/checkstyle.xml" />
<arg value="--standard=${basedir}/build/phpcs.xml" />
<arg path="${basedir}/app" />
</exec>
</target>
<target name="phpdox" description="Generate API documentation using phpDox">
<exec executable="phpdox">
<arg value="-f" />
<arg value="${basedir}/build/phpdox.xml" />
</exec>
</target>
<target name="phploc" description="Measure project size using PHPLOC">
<exec executable="phploc">
<arg value="--log-csv" />
<arg value="${basedir}/build/logs/phploc.csv" />
<arg path="${basedir}/app" />
</exec>
</target>
<target name="phpmd" description="Perform project mess detection using PHPMD and print human readable output. Intended for usage on the command line before committing.">
<exec executable="phpmd">
<arg path="${basedir}/app" />
<arg value="text" />
<arg value="${basedir}/build/phpmd.xml" />
</exec>
</target>
<target name="phpmd-ci" description="Perform project mess detection using PHPMD creating a log file for the continuous integration server">
<exec executable="phpmd">
<arg path="${basedir}/app" />
<arg value="xml" />
<arg value="${basedir}/build/phpmd.xml" />
<arg value="--reportfile" />
<arg value="${basedir}/build/logs/pmd.xml" />
</exec>
</target>
<target name="phpunit" description="Run unit tests with PHPUnit">
<exec executable="phpunit" failonerror="true">
<arg value="-c" />
<arg value="${basedir}/phpunit.xml.dist" />
<arg value="--coverage-html" />
<arg value="${basedir}/build/coverage" />
</exec>
</target>
<target name="storage-permissions" depends="storage-permissions.unix,storage-permissions.windows" description="Setting storage permissions" />
<target name="storage-permissions.unix" depends="storage.unix.check" if="storage.unix.exist" description="Setting storage permissions on unix">
<echo>Setting app/storage to 777</echo>
<chmod file="${basedir}/app/storage/**" perm="777" type="dir" failonerror="false" />
</target>
<target name="storage-permissions.windows" depends="storage.windows.check" if="storage.windows.exist" description="Setting storage permissions on windows">
<echo>Setting app/storage to writable</echo>
<attrib file="${basedir}/app/storage/**" perm="+R" failonerror="false" />
</target>
<!--// Check to see it the app/storage folder exist, if so, then can change permissions //-->
<target name="storage.unix.check" description="Check for app/storage on unix">
<condition property="storage.unix.exist">
<and>
<available file="${basedir}/app/storage" type="dir" />
<os family="unix" />
</and>
</condition>
</target>
<!--// Check to see it the app/storage folder exist, if so, then can change permissions //-->
<target name="storage.windows.check" description="Check for app/storage on windows">
<condition property="storage.windows.exist">
<and>
<available file="${basedir}/app/storage" type="dir" />
<os family="windows" />
</and>
</condition>
</target>
<target name="prepare" depends="clean-build" description="Prepare for build">
<echo>Making the build artifact folders</echo>
<mkdir dir="${basedir}/build/api" />
<mkdir dir="${basedir}/build/code-browser" />
<mkdir dir="${basedir}/build/coverage" />
<mkdir dir="${basedir}/build/logs" />
<mkdir dir="${basedir}/build/pdepend" />
</target>
И вывод консоли: (Примечание: если вы видите в Lint: есть критическая синтаксическая ошибка, но сборка прошла успешно)
GitHub PR #<a href="https://github.com/yousafsyed/fyp_fuzzy_keyword/pull/7">7</a>, PR opened
Building in workspace /var/lib/jenkins/workspace/fypproject
> git rev-parse --is-inside-work-tree # timeout=10
Fetching changes from the remote Git repository
> git config remote.origin.url [email protected]:yousafsyed/fyp_fuzzy_keyword.git # timeout=10
Fetching upstream changes from [email protected]:yousafsyed/fyp_fuzzy_keyword.git
> git --version # timeout=10
using GIT_SSH to set credentials
> git -c core.askpass=true fetch --tags --progress [email protected]:yousafsyed/fyp_fuzzy_keyword.git +refs/pull/*:refs/remotes/origin/pr/*
Seen branch in repository origin/master
Seen branch in repository origin/pr/1/head
Seen branch in repository origin/pr/1/merge
Seen branch in repository origin/pr/2/head
Seen branch in repository origin/pr/2/merge
Seen branch in repository origin/pr/3/head
Seen branch in repository origin/pr/3/merge
Seen branch in repository origin/pr/4/head
Seen branch in repository origin/pr/4/merge
Seen branch in repository origin/pr/5/head
Seen branch in repository origin/pr/5/merge
Seen branch in repository origin/pr/6/head
Seen branch in repository origin/pr/7/head
Seen branch in repository origin/pr/7/merge
Seen branch in repository origin/test
Seen 15 remote branches
Checking out Revision c21af3b12115a29c826702a4acf08de24483f27d (origin/pr/7/merge)
> git config core.sparsecheckout # timeout=10
> git checkout -f c21af3b12115a29c826702a4acf08de24483f27d
First time build. Skipping changelog.
[fypproject] $ ant build-clean
Unable to locate tools.jar. Expected to find it in /usr/lib/jvm/java-7-openjdk-amd64/lib/tools.jar
Buildfile: /var/lib/jenkins/workspace/fypproject/build.xml
clean-build:
[echo] Cleaning out the build artifacts
[delete] Deleting directory /var/lib/jenkins/workspace/fypproject/build/api
[delete] Deleting directory /var/lib/jenkins/workspace/fypproject/build/code-browser
[delete] Deleting directory /var/lib/jenkins/workspace/fypproject/build/coverage
[delete] Deleting directory /var/lib/jenkins/workspace/fypproject/build/logs
[delete] Deleting directory /var/lib/jenkins/workspace/fypproject/build/pdepend
clean-composer:
[echo] Cleaning out the composer artifacts
[delete] Deleting directory /var/lib/jenkins/workspace/fypproject/vendor
[delete] Deleting: /var/lib/jenkins/workspace/fypproject/composer.lock
clean:
lint:
[apply] Errors parsing /var/lib/jenkins/workspace/fypproject/app/Libraries/FuzzyObject.php
[apply] PHP Parse error: syntax error, unexpected '}', expecting ',' or ';' in /var/lib/jenkins/workspace/fypproject/app/Libraries/FuzzyObject.php on line 15
[apply] Result: 255
prepare:
[echo] Making the build artifact folders
[mkdir] Created dir: /var/lib/jenkins/workspace/fypproject/build/api
[mkdir] Created dir: /var/lib/jenkins/workspace/fypproject/build/code-browser
[mkdir] Created dir: /var/lib/jenkins/workspace/fypproject/build/coverage
[mkdir] Created dir: /var/lib/jenkins/workspace/fypproject/build/logs
[mkdir] Created dir: /var/lib/jenkins/workspace/fypproject/build/pdepend
storage.unix.check:
storage-permissions.unix:
storage.windows.check:
storage-permissions.windows:
storage-permissions:
composer.check:
composer-install:
[echo] Installing dependencies
[exec] You are running composer with xdebug enabled. This has a major impact on runtime performance. See https://getcomposer.org/xdebug
[exec] Loading composer repositories with package information
[exec] Updating dependencies (including require-dev)
[exec] - Installing symfony/polyfill-util (v1.2.0)
[exec] Loading from cache
[exec] - Installing jakub-onderka/php-console-color (0.1)
[exec] Loading from cache
[exec]
[exec] - Installing jakub-onderka/php-console-highlighter (v0.3.2)
[exec] Loading from cache
[exec]
[exec] - Installing dnoegel/php-xdg-base-dir (0.1)
[exec] Loading from cache
[exec]
[exec] - Installing paragonie/random_compat (v1.4.1)
[exec] Loading from cache
[exec]
[exec] - Installing nesbot/carbon (1.21.0)
[exec] Loading from cache
[exec]
[exec] - Installing mtdowling/cron-expression (v1.1.0)
[exec] Loading from cache
[exec]
[exec] - Installing monolog/monolog (1.20.0)
[exec] Loading from cache
[exec]
[exec] - Installing league/flysystem (1.0.24)
[exec] Loading from cache
[exec]
[exec]
[exec] - Installing mockery/mockery (0.9.5)
[exec] Loading from cache
[exec]
[exec] - Installing symfony/yaml (v3.1.2)
[exec] Loading from cache
[exec]
[exec] - Installing sebastian/version (1.0.6)
[exec] Loading from cache
[exec]
[exec] - Installing sebastian/global-state (1.1.1)
[exec] Loading from cache
[exec]
[exec] - Installing sebastian/recursion-context (1.0.2)
[exec] Loading from cache
[exec]
[exec] symfony/var-dumper suggests installing ext-symfony_debug ()
[exec] symfony/translation suggests installing symfony/config ()
[exec] symfony/routing suggests installing doctrine/annotations (For using the annotation loader)
[exec] symfony/routing suggests installing symfony/config (For using the all-in-one router or any loader)
[exec] symfony/routing suggests installing symfony/dependency-injection (For loading routes from a service)
[exec] symfony/routing suggests installing symfony/expression-language (For using expression matching)
[exec] symfony/event-dispatcher suggests installing symfony/dependency-injection ()
[exec] symfony/http-kernel suggests installing symfony/browser-kit ()
[exec] symfony/http-kernel suggests installing symfony/class-loader ()
[exec] symfony/http-kernel suggests installing symfony/config ()
[exec] symfony/http-kernel suggests installing symfony/dependency-injection ()
[exec] paragonie/random_compat suggests installing ext-libsodium (Provides a modern crypto API that can be used to generate random bytes.)
[exec] monolog/monolog suggests installing aws/aws-sdk-php (Allow sending log messages to AWS services like DynamoDB)
[exec] monolog/monolog suggests installing doctrine/couchdb (Allow sending log messages to a CouchDB server)
[exec] monolog/monolog suggests installing ext-amqp (Allow sending log messages to an AMQP server (1.0+ required))
[exec] monolog/monolog suggests installing ext-mongo (Allow sending log messages to a MongoDB server)
[exec] monolog/monolog suggests installing graylog2/gelf-php (Allow sending log messages to a GrayLog2 server)
[exec] monolog/monolog suggests installing mongodb/mongodb (Allow sending log messages to a MongoDB server via PHP Driver)
[exec] monolog/monolog suggests installing php-amqplib/php-amqplib (Allow sending log messages to an AMQP server using php-amqplib)
[exec] monolog/monolog suggests installing php-console/php-console (Allow sending log messages to Google Chrome)
[exec] monolog/monolog suggests installing rollbar/rollbar (Allow sending log messages to Rollbar)
[exec] monolog/monolog suggests installing ruflin/elastica (Allow sending log messages to an Elastic Search server)
[exec] monolog/monolog suggests installing sentry/sentry (Allow sending log messages to a Sentry server)
[exec] league/flysystem suggests installing league/flysystem-aws-s3-v2 (Allows you to use S3 storage with AWS SDK v2)
[exec] league/flysystem suggests installing league/flysystem-aws-s3-v3 (Allows you to use S3 storage with AWS SDK v3)
[exec] league/flysystem suggests installing league/flysystem-azure (Allows you to use Windows Azure Blob storage)
[exec] league/flysystem suggests installing league/flysystem-cached-adapter (Flysystem adapter decorator for metadata caching)
[exec] league/flysystem suggests installing league/flysystem-copy (Allows you to use Copy.com storage)
[exec] league/flysystem suggests installing league/flysystem-dropbox (Allows you to use Dropbox storage)
[exec] league/flysystem suggests installing league/flysystem-eventable-filesystem (Allows you to use EventableFilesystem)
[exec] league/flysystem suggests installing league/flysystem-rackspace (Allows you to use Rackspace Cloud Files)
[exec] league/flysystem suggests installing league/flysystem-sftp (Allows you to use SFTP server storage via phpseclib)
[exec] league/flysystem suggests installing league/flysystem-webdav (Allows you to use WebDAV storage)
[exec] league/flysystem suggests installing league/flysystem-ziparchive (Allows you to use ZipArchive adapter)
[exec] psy/psysh suggests installing ext-pdo-sqlite (The doc command requires SQLite to work.)
[exec] laravel/framework suggests installing aws/aws-sdk-php (Required to use the SQS queue driver and SES mail driver (~3.0).)
[exec] laravel/framework suggests installing doctrine/dbal (Required to rename columns and drop SQLite columns (~2.4).)
[exec] laravel/framework suggests installing guzzlehttp/guzzle (Required to use the Mailgun and Mandrill mail drivers and the ping methods on schedules (~5.3|~6.0).)
[exec] laravel/framework suggests installing league/flysystem-aws-s3-v3 (Required to use the Flysystem S3 driver (~1.0).)
[exec] laravel/framework suggests installing league/flysystem-rackspace (Required to use the Flysystem Rackspace driver (~1.0).)
[exec] laravel/framework suggests installing pda/pheanstalk (Required to use the beanstalk queue driver (~3.0).)
[exec] laravel/framework suggests installing predis/predis (Required to use the redis cache and queue drivers (~1.0).)
[exec] laravel/framework suggests installing pusher/pusher-php-server (Required to use the Pusher broadcast driver (~2.0).)
[exec] laravel/framework suggests installing symfony/psr-http-message-bridge (Required to psr7 bridging features (0.2.*).)
[exec] sebastian/global-state suggests installing ext-uopz (*)
[exec] phpunit/phpunit suggests installing phpunit/php-invoker (~1.1)
[exec] Writing lock file
[exec] Generating autoload files
[exec] > Illuminate\Foundation\ComposerScripts::postUpdate
[exec] > php artisan optimize
[exec] Generating optimized class loader
[exec] Compiling common classes
composer-update:
composer:
phpunit:
[exec] PHPUnit 4.8.26 by Sebastian Bergmann and contributors.
[exec]
[exec]
[exec]
[exec] Time: 165 ms, Memory: 12.75MB
[exec]
[exec] No tests executed!
[exec]
[exec] Generating code coverage report in Clover XML format ... done
[exec]
[exec] Generating code coverage report in HTML format ... done
build-common:
phploc:
[exec] phploc 3.0.1 by Sebastian Bergmann.
[exec]
[exec] Directories 13
[exec] Files 30
[exec]
[exec] Size
[exec] Lines of Code (LOC) 1484
[exec] Comment Lines of Code (CLOC) 446 (30.05%)
[exec] Non-Comment Lines of Code (NCLOC) 1038 (69.95%)
[exec] Logical Lines of Code (LLOC) 375 (25.27%)
[exec] Classes 257 (68.53%)
[exec] Average Class Length 8
[exec] Minimum Class Length 0
[exec] Maximum Class Length 98
[exec] Average Method Length 3
[exec] Minimum Method Length 0
[exec] Maximum Method Length 13
[exec] Functions 10 (2.67%)
[exec] Average Function Length 1
[exec] Not in classes or functions 108 (28.80%)
[exec]
[exec] Cyclomatic Complexity
[exec] Average Complexity per LLOC 0.13
[exec] Average Complexity per Class 2.66
[exec] Minimum Class Complexity 1.00
[exec] Maximum Class Complexity 22.00
[exec] Average Complexity per Method 1.76
[exec] Minimum Method Complexity 1.00
[exec] Maximum Method Complexity 5.00
[exec]
[exec] Dependencies
[exec] Global Accesses 0
[exec] Global Constants 0 (0.00%)
[exec] Global Variables 0 (0.00%)
[exec] Super-Global Variables 0 (0.00%)
[exec] Attribute Accesses 100
[exec] Non-Static 100 (100.00%)
[exec] Static 0 (0.00%)
[exec] Method Calls 155
[exec] Non-Static 109 (70.32%)
[exec] Static 46 (29.68%)
[exec]
[exec] Structure
[exec] Namespaces 14
[exec] Interfaces 0
[exec] Traits 0
[exec] Classes 29
[exec] Abstract Classes 3 (10.34%)
[exec] Concrete Classes 26 (89.66%)
[exec] Methods 59
[exec] Scope
[exec] Non-Static Methods 58 (98.31%)
[exec] Static Methods 1 (1.69%)
[exec] Visibility
[exec] Public Methods 55 (93.22%)
[exec] Non-Public Methods 4 (6.78%)
[exec] Functions 9
[exec] Named Functions 0 (0.00%)
[exec] Anonymous Functions 9 (100.00%)
[exec] Constants 0
[exec] Global Constants 0 (0.00%)
[exec] Class Constants 0 (0.00%)
pdepend:
[exec] PHP_Depend 1.1.4 by Manuel Pichler
[exec]
[exec] Parsing source files:
[exec] .............................. 30
[exec]
[exec] Executing Coupling-Analyzer:
[exec] ....... 154
[exec]
[exec] Executing CyclomaticComplexity-Analyzer:
[exec] ....... 154
[exec]
[exec] Executing Dependency-Analyzer:
[exec] .... 95
[exec]
[exec] Executing Inheritance-Analyzer:
[exec] . 40
[exec]
[exec] Executing NodeCount-Analyzer:
[exec] .... 95
[exec]
[exec] Executing NodeLoc-Analyzer:
[exec] ...... 121
[exec]
[exec] Generating pdepend log files, this may take a moment.
[exec]
[exec] The following errors occured:
[exec] Unexpected token: class, line: 20, col: 33, file: /var/lib/jenkins/workspace/fypproject/app/Exceptions/Handler.php.
[exec] Unexpected token: class, line: 17, col: 73, file: /var/lib/jenkins/workspace/fypproject/app/Http/Kernel.php.
[exec] Unexpected token: }, line: 15, col: 1, file: /var/lib/jenkins/workspace/fypproject/app/Libraries/FuzzyObject.php.
[exec] Unexpected token: class, line: 35, col: 62, file: /var/lib/jenkins/workspace/fypproject/app/Providers/FuzzySearchServiceProvider.php.
[exec]
[exec]
[exec] Time: 00:00; Memory: 12.25Mb
phpmd-ci:
[exec] Result: 2
phpcs-ci:
phpcpd:
[exec] phpcpd 2.0.4 by Sebastian Bergmann.
[exec]
[exec] 0.00% duplicated lines out of 1484 total lines of code.
[exec]
[exec] Time: 51 ms, Memory: 4.00Mb
phpcb:
build-clean:
BUILD SUCCESSFUL
Total time: 31 seconds
Finished: SUCCESS
Задача ещё не решена.
Других решений пока нет …