Continuous integration for VIP Go repositories.
vip-go-ci
is a PHP-program that can be called for latest commits pushed to Pull-Requests on GitHub, looking for problems in the code using PHP linting, PHPCS, and a SVG scanner -- and then posting back to GitHub comments and reviews, detailing the issues found. vip-go-ci
can also automatically approve Pull-Requests that contain already-approved files (registered in a special database) and/or contain file-types that are approvable by default.
vip-go-ci
is to be called from the commandline, using several arguments specifying the repository and commit-ID to scan, and various other options. During execution, vip-go-ci
will provide a detailed log of its actions and what it encounters. The program expects a fully-functional git-repository to be stored locally on the computer running it, were from it can extract various information.
It has different behaviours for different scanning-methods. For PHP linting, it will loop through every file existing in the code-base, and post a generic Pull-Request comment for any issues it finds with the PHP-code. In case of PHPCS scanning, however, it will scan only the files affected by the Pull-Request using PHPCS, and for any issues outputted by PHPCS, post a comment on the commit with the issue, in the form of a 'GitHub Review' (this includes inline comments and a review-message). SVG scanning behaves similar to PHPCS scanning. What scanning is performed can be customised on the command-line.
This program comes with a small utility, tools-init.sh
, that will install PHPCS and related tools in your home-directory upon execution. This utility will check if the tools required are installed, and if not, install them, or if they are, check if they are of the latest version, and upgrade them as needed. It is highly recommended to run this utility on a regular basis.
vip-go-ci
can be run standalone on the console. This is mainly useful for debugging purposes and to understand if everything is correctly configured, but for production purposes it should ideally be run via some kind of build management software (for instance TeamCity or GitHub Actions). To run vip-go-ci
on the console, a few tools are required. The tools-init.sh
script that is included will install the tools needed.
After the tools have been installed, vip-go-ci.php
can be run on your local console to scan a particular commit in a particular repository:
./vip-go-ci.php --repo-owner=
repo-owner
--repo-name=repo-name
--commit=commit-ID
--token=GitHub-Access-Token
--local-git-repo=Local-Git-Repo
--phpcs-path=phpcs-path
--phpcs=true --lint=true --autoapprove=true --autoapprove-filetypes=File-Types
-- where repo-owner
is the GitHub repository-owner, repo-name
is the name of the repository, commit-ID
is the SHA-hash identifying the commit, Local-Git-Repo
is a path to the git-repository used to scan, GitHub-Access-Token
is a access-token created on GitHub that allows reading and commenting on the repository in question, path-to-phpcs
is a full path to PHPCS, and File-Types
refers to a list of file-types to be approved (such as css,txt,pdf
).
The output from vip-go-ci
you will get by running the command above should be something like this:
[ 2018-04-16T14:10:04+00:00 -- 0 ] Initializing...; []
[ 2018-04-16T14:10:04+00:00 -- 0 ] Trying to get information about the user the GitHub-token belongs to; []
[ 2018-04-16T14:10:05+00:00 -- 0 ] Starting up...; {
"options": {
"repo-owner": "mygithubuser",
"repo-name": "testing123",
"commit": "f978c17f8f648e5ce10aa16694c74a5544b1670e",
"local-git-repo": "\/tmp\/git-testing123",
"phpcs": true,
"lint": true,
"phpcs-path": "\/home\/myuser\/vip-go-ci-tools\/phpcs\/bin\/phpcs",
"phpcs-standard": "WordPress-VIP-Go",
"phpcs-severity": 5,
"branches-ignore": [],
"autoapprove": true,
"autoapprove-filetypes": [ "css", "txt", "pdf ],
"php-path": "php",
"debug-level": 0,
"dry-run": false
}
}
[ 2018-04-16T14:10:05+00:00 -- 0 ] Fetching all open Pull-Requests from GitHub; {
"repo_owner": "mygithubuser",
"repo_name": "testing123",
"commit_id": "f978c17f8f648e5ce10aa16694c74a5544b1670e",
"branches_ignore": []
}
[ 2018-04-16T14:10:14+00:00 -- 0 ] Fetching information about all commits made to Pull-Request #17 from GitHub; {
"repo_owner": "mygithubuser",
"repo_name": "testing123",
"pr_number": 17
}
[ 2018-04-16T14:10:48+00:00 -- 0 ] About to clean up generic PR comments on Github; {
"repo_owner": "mygithubuser",
"repo_name": "testing123",
"commit_id": "f978c17f8f648e5ce10aa16694c74a5544b1670e",
"branches_ignore": [],
"dry_run": false
}
[ 2018-04-16T14:10:48+00:00 -- 0 ] About to lint PHP-files; {
"repo_owner": "mygithubuser",
"repo_name": "testing123",
"commit_id": "f978c17f8f648e5ce10aa16694c74a5544b1670e"
}
[ 2018-04-16T14:10:50+00:00 -- 0 ] About to PHP-lint file; {
"repo_owner": "mygithubuser",
"repo_name": "testing123",
"commit_id": "f978c17f8f648e5ce10aa16694c74a5544b1670e",
"filename": "bla-1.php",
"temp_file_name": "\/tmp\/lint-scan-jniXTN"
}
[ 2018-04-16T14:10:50+00:00 -- 0 ] Fetching file-contents from local Git repository; {
"repo_owner": "mygithubuser",
"repo_name": "testing123",
"commit_id": "f978c17f8f648e5ce10aa16694c74a5544b1670e",
"filename": "bla-2.php",
"local_git_repo": "\/tmp\/git-testing123"
}
[ 2018-04-16T14:10:51+00:00 -- 0 ] About to PHPCS-scan all files affected by any of the Pull-Requests; {
"repo_owner": "mygithubuser",
"repo_name": "testing123",
"commit_id": "f978c17f8f648e5ce10aa16694c74a5544b1670e"
}
[ 2018-04-16T14:10:51+00:00 -- 0 ] Fetching file-contents from local Git repository; {
"repo_owner": "mygithubuser",
"repo_name": "testing123",
"commit_id": "f978c17f8f648e5ce10aa16694c74a5544b1670e",
"filename": "bla-2.php",
"local_git_repo": "\/tmp\/git-testing123"
}
[ 2018-04-16T14:10:51+00:00 -- 0 ] About to PHPCS-scan file; {
"repo_owner": "mygithubuser",
"repo_name": "testing123",
"commit_id": "f978c17f8f648e5ce10aa16694c74a5544b1670e",
"filename": "bla-2.php",
"temp_file_name": "\/tmp\/phpcs-scan-U3DbUE.php"
}
[ 2018-04-16T14:10:52+00:00 -- 0 ] About to submit generic PR comment to GitHub about issues; {
"repo_owner": "mygithubuser",
"repo_name": "testing123",
"commit_id": "f978c17f8f648e5ce10aa16694c74a5544b1670e",
"results": {
"issues": {
"12": []
},
"stats": {
...
}
},
"dry_run": false
}
[ 2018-04-16T14:10:52+00:00 -- 0 ] About to submit comment(s) to GitHub about issue(s); {
"repo_owner": "mygithubuser",
"repo_name": "testing123",
"commit_id": "f978c17f8f648e5ce10aa16694c74a5544b1670e",
"results": {
"issues": {
"12": []
},
"stats": {
...
}
},
"dry_run": false
}
[ 2018-04-16T14:10:52+00:00 -- 0 ] Shutting down; {
"run_time_seconds": 48,
"run_time_measurements": {
"git_cli": 0.0699622631073,
"github_forced_wait": 11.001686811447,
"github_api": 30.39110994339,
"lint_scan_commit": 1.7449381351471,
"git_repo_scandir": 9.8228454589844e-5,
"lint_scan_single_file": 0.22931528091431,
"git_repo_fetch_file": 0.00043511390686035,
"save_temp_file": 0.00095939636230469,
"php_lint_cli": 0.20436358451843,
"phpcs_scan_commit": 2.2697520256042,
"phpcs_scan_single_file": 0.33324813842773,
"phpcs_cli": 0.32072472572327,
"git_repo_blame_for_file": 0.020441055297852
},
"results": {
"issues": {
"12": []
},
"stats": {
...
}
}
}
You can set up vip-go-ci
with TeamCity, so that when a commit gets pushed to GitHub, vip-go-ci.php
will run and scan the commit. TeamCity is not required, any other similar build management software can be used.
This flowchart shows how vip-go-ci
interacts with TeamCity, git, GitHub, and the utilities it uses:
To get vip-go-ci
working, follow these steps:
-
Create a project, and link it to the GitHub repository you wish to scan
-
Create a build-runner by clicking on
Create build configuration
on the project -
Define a build-feature, by clicking on
Add Build Feature
(located inBuild Features
, found in the project-settings). Define the type of the build-feature asCommit status publisher
,VCS Root
asAll attached VCS Roots
, andPublisher
asGitHub
. -
Click on
Version Control Settings
(in the project-settings), make sure to do the following:- Checkout directory as
Custom path
, and path as something unique and unreadable from other users (local-directory for the build-runner user would be optimal). - Click on
Clean all files in the checkout directory before the build
.
- Checkout directory as
-
Define parameters for the build. In the project-settings, click on
Parameters
, then click 'Add Parameter' and follow the on-screen instructions. The parameters that need to be added areREPO_ORG
,REPO_NAME
, andREPO_TOKEN
and with values appropriate with for the repository which is to be scanned. -
Make sure the build-runner is of the
Command Line
type, thatIf all previous steps finished successfully
is chosen, and thatCustom Script
is chosen for the runRun
field. -
Add a shell-script into the
Custom Script
field, the script should look something like the following:
#
# If vip-go-ci-tools does not exist, get it in place.
# by fetching and running tools-init. If it does exist,
# run tools-init.sh anyway to check for updates.
#
if [ -d ~/vip-go-ci-tools ] ; then
bash ~/vip-go-ci-tools/vip-go-ci/tools-init.sh
else
wget https://raw.githubusercontent.com/Automattic/vip-go-ci/master/tools-init.sh -O tools-init.sh && \
bash tools-init.sh && \
rm -f tools-init.sh
fi
#
# Make sure to disable PHPCS-scanning by default
#
PHPCS_ENABLED=${PHPCS_ENABLED:-false}
#
# Actually run vip-go-ci
#
php ~/vip-go-ci-tools/vip-go-ci/vip-go-ci.php --repo-owner="$REPO_ORG" --repo-name="$REPO_NAME" --commit="$BUILD_VCS_NUMBER" --token="$REPO_TOKEN" --local-git-repo="%system.teamcity.build.checkoutDir%" --phpcs="$PHPCS_ENABLED" --lint="$LINTING_ENABLED" --phpcs-path="$HOME/vip-go-ci-tools/phpcs/bin/phpcs"
Note that the script has built-in commands to install all the utilities vip-go-ci
relies on (via tools-init.sh
), so that they will be configured automatically, and updated automatically as well.
The parameters should be pretty-much self-explanatory. Note that --commit should be left exactly as shown above, as $BUILD_VCS_NUMBER
is populated by TeamCity. Other variables, $REPO_ORG
, $REPO_NAME
and $REPO_TOKEN
are populated by TeamCity on run-time according to your settings (see above).
That is it. Now TeamCity should run vip-go-ci.php
for every incoming commit to any Pull-Request associated with the repository.
You can start a local instance of TeamCity in Docker if you like.
docker-compose up -d
open http://localhost:8111
To start with multiple agents (for example, three):
docker-compose up -d --scale agent=3
Alternatively, if you do not wish to run TeamCity in a Docker-instance, you can download it and set it up manually.
vip-go-ci.php
exits with different UNIX exit codes depending on what problems were found and if any system issues were encountered:
- Code
0
: Normal, no errors were found in the code scanned and no fatal system errors were encountered. There could have been warnings found in the code, though. - Code
250
: Scanning was completed, but some errors were found in the code. - Code
251
: Exiting due to a system problem. - Code
252
: A fatal problem with GitHub was encountered leading to an exit. - Code
253
: A problem with usage options was detected, leading to an exit.
vip-go-ci
has support for various features not documented above, such as dismissing stale reviews, setting specific options via the repository being scanned and more. These features are configurable via the command-line or the environment, and are documented below.
Note: To make it easier to read the documention below, some required parameters are not shown (such as --repo-owner
, --repo-name
, etc).
If you run vip-go-ci
in an environment such as TeamCity
or GitHub Actions
, it can be useful to configure certain parameters via environmental variables. This way, the parameters are not visible in any logs and cannot be seen in the process-tree during run-time. With vip-go-ci
, this can easily be done by running it this way:
./vip-go-ci.php --commit="$COMMIT_ID" --phpcs=true --lint=true --autoapprove=true --autoapprove-filetypes="css,txt,pdf" --env-options="repo-owner=GH_REPO_OWNER,repo-name=GH_REPO_NAME,token=GH_TOKEN"
In this case, --repo-owner
will be read from the $GH_REPO_OWNER
environmental variable, --repo-name
from $GH_REPO_NAME
, and so forth. Other parameters are set via the command-line.
Any parameter can be read from the environment, not just those shown. Parameters read from environmental variables are processed and sanitized exactly the same way as parameters directly specified on the command-line. You can configure some parameters from the command-line directly, while others are read from the environment. Parameters configured via the command-line cannot be configured also from the environment; in such situations, the latter ones will be ignored on run-time.
Two options can currently be configured via a repository config-file. This way, users with commit-access to a git repository can influence the behaviour of vip-go-ci
. The idea is to allow users flexibility in how scanning is performed. Various sanity checks are made to the configuration options read. Currently, the options that can be specified via repository options are --phpcs-severity
and --post-generic-pr-support-comments
. Any default configuration is overwritten during run-time by the new value, should it be valid.
The feature can be enabled or disabled via --repo-options
; by default it is disabled. To use the feature, make sure a .vipgoci_options
file can be found at the root of the relevant git-repository, containing something like this:
{"phpcs-severity":5,"post-generic-pr-support-comments":false}
Then run vip-go-ci
like this:
./vip-go-ci.php --repo-options=true
If you wish to limit the options configurable via repository options file, you can specify which options can be configured by using --repo-options-allowed, like this:
./vip-go-ci.php --repo-options=true --repo-options-allowed="phpcs-severity,post-generic-pr-support-comments"
Also supported is the phpcs-sniffs-exclude
option. This is an array parameter and if it is specified in the options file, the items specified will be appended to the options specified on the command line. To configure this option, one can specify something like this in the repository options file:
{"phpcs-sniffs-exclude":["WordPressVIPMinimum.JS.InnerHTML", "WordPress.WP.CronInterval"]}
The phpcs-sniffs-include
option is also available, and it is configured in the same way as the phpcs-sniffs-exclude
option. Note that it works differently behind the scenes, as it will write out a new PHPCS standard on run-time, containing the sniffs to be included as well as the original PHPCS standard, and will then use this standard from then on. The phpcs-sniffs-include
option is used in this way:
{"phpcs-sniffs-include":["WordPress.DB.DirectDatabaseQuery"]}
Please note that should any of the PHPCS sniffs specified be invalid, a warning will be posted on any Pull-Request scanned. The warning will be removed during next scan and not posted again if the issue is fixed.
Also available is the skip-execution
option:
{"skip-execution":true}
This will make execution of vip-go-ci
stop after initial startup, avoiding all further processing and scanning.
Should the configuration file not be found, any configuration value not be valid, or altering of the particular option is not allowed, the option will not be altered on run-time. Note that not all options need to be set in the configuration file, only those desired. The file is expected to be a parsable, valid JSON.
This feature might be extended to other options in the future.
To help users understand better why a bot is posting comments and reviews on their Pull-Requests, and sometimes automatically approving them, it can be helpful to have a bit of information added to the comments vip-go-ci
posts. This feature serves this purpose.
To have a URL posted, simply run vip-go-ci
with a --informational-url
parameter:
./vip-go-ci.php --informational-url=https://myservice.mycompany.is/info-on-scanning
The URL will be included in any generic Pull-Request comments or Pull-Request reviews submitted.
Support for checking for issues in PHP files by using PHPCS scanning is supported. The behaviour of PHPCS scanning can be configured using several options.
An example of how PHPCS can be used:
./vip-go-ci.php --phpcs=true --phpcs-path="$HOME/vip-go-ci-tools/phpcs/bin/phpcs" --phpcs-standard="WordPress-VIP-Go,PHPCompatibilityWP" --phpcs-sniffs-exclude="WordPress.WP.PostsPerPage.posts_per_page_posts_per_page" --phpcs-sniffs-include="WordPress.DB.DirectDatabaseQuery" --phpcs-severity=1 --phpcs-runtime-set="testVersion 7.3-" --phpcs-skip-scanning-via-labels-allowed=true
With these settings, PHPCS is turned on, is expected to be found in the path shown above, should use two PHPCS standards (WordPress-VIP-Go
and PHPCompatibilityWP
), while excluding one particular PHPCS sniff and specifically include another one. When executing PHPCS, one runtime option should be set (testVersion 7.3-
) and severity level should be 1
. Also, users can ask to skip scanning particular Pull-Requests by setting a label named skip-phpcs-scan
.
Any number of PHPCS standards can be specified, and any number of runtime settings as well. Also, see section above about configuring options via repository file.
Should any of the PHPCS sniffs included or excluded be invalid, this is reported in the relevant Pull-Requests.
vip-go-ci
supports scanning SVG files for dangerous tags. The scanning is accomplished by a SVG scanner, while vip-go-ci
takes care of posting the issues found.
To make use of this feature, the --svg-checks
and --svg-scanner-path
options should be used. For example:
./vip-go-ci.php --svg-checks=true --svg-scanner-path="$HOME/vip-go-ci-tools/vip-go-svg-sanitizer/svg-scanner.php"
With these options, SVG scanning is turned on and a scanner at a particular path location is to be used.
vip-go-ci
can auto-approve Pull-Requests that only alter particular types of files. The 'type' is based on file-ending, such as .txt
. The idea is to allow faster approvals of Pull-Requests that do not need to be reviewed or do not need any automated feedback.
For instance:
./vip-go-ci.php --autoapprove=true --autoapprove-filetypes="css,gif,ico,png,jpg" --autoapprove-label="auto-approved"
-- with this configuration, any Pull-Requests that only alter files ending with .css
, .gif
, etc., are automatically approved by vip-go-ci
. Also, a label will be added to the automatically approved Pull-Requests, named auto-approved
.
Auto-approvals can be configured so to auto-approve Pull-Requests that only change comments or whitespacing in PHP files. For instance:
./vip-go-ci.php --autoapprove=true --autoapprove-php-nonfunctional-changes=true --autoapprove-label="auto-approved"
With this setting, any PHP files having only whitespacing changes or updating to comments, will be automatically approved.
Note that vip-go-ci
will collect which files of the relevant Pull-Request are approved, whether .css
, .gif
, .php
or other, and if all the files altered by it have been found to be auto-approvable, the whole Pull-Request will be approved automatically. This applies also to the Hashes API (see below).
This feature is useful when you want to automatically approve Pull-Requests containing PHP or JavaScript files that are already known to be good and are approved already, so no manual reviewing is needed. To make use of this feature, you will need a database of files already approved. You will also have to be using the auto-approvals feature.
The feature can be activated using the --hashes-api
parameter and by specifying a HTTP API endpoint. For instance:
./vip-go-ci.php --autoapprove=true --hashes-api=true --hashes-api-url=https://myservice.mycompany.is/wp-json/viphash/
Configured this way, vip-go-ci
will make HTTP API requests for any PHP or JavaScript file it sees being altereed in Pull-Requests it scans. The HTTP API requests would look like this:
https://myservice.mycompany.is/wp-json/viphash/v1/hashes/id/[HASH]
where [HASH]
is a SHA1 hash of a particular PHP or JavaScript file, after it all comments and whitespaces have been removed from them. vip-go-ci
expectes a JSON result like this from the HTTP API:
[{"status":"true"},{"status":"true"}]
The JSON result can contain other fields, but they are not used. Note that a single "false" status is enough to make sure a file is considered not approved.
An open-source tool to label files as approved or non-approved is available here. It requires a HTTP API service that vip-go-ci
communicates with as well.
Sometimes users do not want specific branches scanned for any issues -- they want them effectively to be ignored. To do this, you can use the --branches-ignore
option.
For example:
./vip-go-ci.php --branches-ignore="foo,bar"
-- with this option in place, any Pull-Requests targetting branches called foo
or bar
will be ignored and no feedback will be posted to them.
If any specific folders should be ignored when linting or PHPCS scanning, one can use the --lint-skip-folders
and/or --phpcs-skip-folders
option parameters. Files in any folders specified in the options, relative to the git repository root, will be ignored when performing linting or PHPCS scanning.
For example:
./vip-go-ci.php --lint-skip-folders="foo,Tests/bar"
-- with this option in place, any files in the foo/
or Tests/bar
folders and subfolders will be exempt from PHP linting. The folders are relative to the git repository. Please note that regular expressions are not supported at this time.
Folders can also be specified in files placed at the root of the repository, .vipgoci_lint_skip_folders
for PHP linting and .vipgoci_phpcs_skip_folders
for PHPCS scanning. Each folder should be on a line of its own in the relevant file, and each path should be relative to the root of the repository. This feature is activated using command-line options, for example:
./vip-go-ci.php --lint-skip-folders-in-repo-options-file=true --phpcs-skip-folders-in-repo-options-file=true
Any folders found in the files at the root of the repository will be merged with options specified on the command-line.
One can limit the number of review comments posted to GitHub Pull-Requests. Also, one can ignore certain comments so that they will not be posted to Pull-Request reviews. This is useful when Pull-Requests are created or updated, and contain many issues.
The options can be used in this way:
./vip-go-ci.php --review-comments-max=15 --review-comments-total-max=70 --review-comments-ignore="Some error message"
-- with these options, the maximum number of noted issues per Pull-Request review comment is 15, and if any additional ones are found these are posted in a separate review comment. Also, total number of active (i.e., not obsolete or deleted) comments authored by the current vip-go-ci
user is 70 for the whole Pull-Request -- no more will be posted when this is reached. Any issues from PHPCS, SVG, etc. scanning containing Some error message
will be ignored.
Sometimes Pull-Request reviews become obsolete, for instance because all the inline comments attached to them become obsolete as the code evolves and problems are fixed. vip-go-ci
can automatically dismiss those reviews so that they do not impede work.
For instance:
./vip-go-ci.php --dismiss-stale-reviews=true
The first parameter, --dismiss-stale-reviews
, enables or disables the feature in whole.
There are further parameters for more advanced usage:
--dismissed-reviews-repost-comments=BOOL
--dismissed-reviews-exclude-reviews-from-team
-- see the --help
for usage instructions.
vip-go-ci
supports posting general support message to newly created Pull-Requests. With this feature configured, vip-go-ci
will post the support message to every Pull-Request that does not have it, given that the Pull-Request is opened against a predefined list of branches. This list is configurable, along with the support message. The messages will be posted only once per Pull-Request.
The feature can be used in the following fashion:
./vip-go-ci.php --post-generic-pr-support-comments=true --post-generic-pr-support-comments-string="This is a generic support message from
vip-go-ci
. We hope this is useful." --post-generic-pr-support-comments-branches="master"
The last parameter can be specified as 'any' to allow posting to any branch.
You can limit what Pull-Requests the generic support message are posted to, given data from the repo-meta API and a criteria specified on the command line. This feature depends on the repo-meta API being configured.
For example:
./vip-go-ci.php --post-generic-pr-support-comments=true --post-generic-pr-support-comments-string="This ..." --post-generic-pr-support-comments-branches="master" --post-generic-pr-support-comments-repo-meta-match="support_message=true,support_plan=true"
With the --post-generic-pr-support-comments-repo-meta-match
parameter added, vip-go-ci
will look at the data returned by the repo-meta API, and check if these fields and their values are found in there for at least one entry. If so, the generic support message will be posted, and not otherwise.
vip-go-ci
can put labels on Pull-Requests indicating level of support provided. With this feature configured, vip-go-ci
will attach a label to every new Pull-Request that does not have it. For this to work, it will need access to a repo-meta API
that needs to be available and vip-go-ci
has to be configured to work with.
This feature can be used in the following way:
./vip-go-ci.php --set-support-level-label=true --repo-meta-api-base-url="http://myrepometa-api.mycompany.is" --repo-meta-api-user-id=7334005 --repo-meta-api-access-token="MY-TOKEN"
Note that by default, all support level labels have a prefix: [Support Level]
. This can be changed by using the --set-support-level-label-prefix
option.
vip-go-ci
supports posting certain information to a HTTP API that will eventually relay the information to a IRC channel. This can of course be any IRC-like system, as long as the HTTP API behaves the same. This is useful if you need to have some information submitted to a monitoring system, for instance.
This feature can be used in this fashion:
./vip-go-ci.php --irc-api-url='https://myservice.mycompany.is/irc-gateway' --irc-api-bot='mycompany-vip-go-ci' --irc-api-room='#vip-go-ci' --irc-api-token='MY-TOKEN'
At this time, only certain messages are posted to IRC, all indicated by a special parameter to the vipgoci_log()
function. See the code for implementation details.
tools-init.sh
will install PHPCS and related tools in your home-directory upon execution. It will keep these tools up to date when run; it should be executed on regular basis to keep everything up to date.
However, once a while tools-init.sh
itself needs to be updated with new versions of these utilities. The file keeps two data entries for each utlity: Version number and SHA1 hash. The version number refers to a release on GitHub, and the hash to the SHA1 hash of the release's .tar.gz
archive on GitHub. The hash is used to make sure that the relevant utility has not changed since last updated in tools-init.sh
.
Versions and hashes can be determined in the following way. Releases of the WordPress-Coding-Standards
utility, for instance, are hosted here. Once a version has been chosen, tools-init.sh
can be updated in the following way:
export WP_CODING_STANDARDS_VER="2.1.1"
Then the hash has to be calculated. First, obtain a .tar.gz
archive for the release from GitHub. The download URL for WordPress-Coding-Standards
is: https://github.com/WordPress/WordPress-Coding-Standards/archive/VERSION.tar.gz
-- simply replace VERSION
with the version to be used. Then run the sha1sum
UNIX utility against the downloaded file. Any other compatibile tool can be used.
For version 2.1.1 of WordPress-Coding-Standards
the hash is added as follows:
export WP_CODING_STANDARDS_SHA1SUM="d35ec268531453cbf2078c57356e38c5f8936e87";
All utilities in tools-init.sh
follow the same pattern.
To run the unitests for vip-go-ci
, you will need to install phpunit
and any dependencies needed (this would include xdebug
). Then run the unittests using the following command:
phpunit tests/ -vv
By using this command, you will run the whole test-suite and get feeback on any errors or warnings.
Note that by default, some tests will be skipped, as these will require a GitHub token to write to GitHub in order to complete, need access to the hashes-to-hashes database, or to a repo-meta API. To enable the testing of these, you need to set up a unittests-secrets.ini
file in the root of the repository. It should include the following fields:
[auto-approvals-secrets]
hashes-api-url=
hashes-oauth-consumer-key=
hashes-oauth-consumer-secret=
hashes-oauth-token=
hashes-oauth-token-secret=
[git-secrets]
github-token= ; Personal access token from GitHub
team-id= ; Team ID to test if present, this is a numeric
team-slug= ; Team slug to test if present, is a string. Should be referencing the same team as team-id.
org-name= ; GitHub organisation name to use in testing
[repo-meta-api-secrets]
repo-meta-api-base-url= ; URL to base of meta API
repo-meta-api-user-id= ; User ID for the meta API
repo-meta-api-access-token= ; Access token for the meta API
repo-owner= ; Repository owner for the test, should be found in meta API
repo-name= ; Repository name for the test
support-tier-name= ; Name of support tier given by meta API
This file is not included, and needs to be configured manually. When that is complete, the tests can be re-run.