Skip to content

Commit

Permalink
update README to reference readthedoc docs
Browse files Browse the repository at this point in the history
  • Loading branch information
Patrick Huang committed Mar 22, 2017
1 parent 1c196fb commit 8fda8ed
Showing 1 changed file with 4 additions and 76 deletions.
80 changes: 4 additions & 76 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -20,85 +20,13 @@ In this project, if you have docker installed:
mvn clean package
docker/runJenkins.sh
```
Then access the local instance at http://localhost:8080/

If you don't have docker:
```
hpiPluginRun.sh
```
Then access the local instance at http://localhost:8080/jenkins/

### How to use it as normal Jenkins job
First you will need to configure Zanata credentials in Jenkins Credentials view (plus e.g. github credential if you want to push commit).
Then you will have two options to use Zanata client to push source to and/or pull translation from Zanata server.

1. use the plugin as a build step
- in you job configuration, you can choose 'Zanata Sync' as a build step and fill in all the information in the UI

2. install Zanata CLI on Jenkins node and use scripting to invoke it
- go to Jenkins global tools configuration view and there will be a Zanata CLI section for you to configure
- in your job configuration, you can choose to install the configured CLI under Build Environment section
- choose a shell builder step and run Zanata CLI from there

Option 1 has the advantage of being installation free and simple to use. It will work on all type of jenkins slave nodes.
It will commit translation after pull automatically if you use Git as SCM.
Disadvantage being that it uses only the included version of Zanata CLI java classes. and you can't do much customization for push and pull.

Option 2 has the advantage of being flexible. You can use all the features and options of [Zanata CLI](http://zanata-client.readthedocs.io/en/release/).
The disadvantage is, you will need to know how to use Zanata CLI. You also need to manually manage source control in your shell script.

### How to configure a job to listen to Zanata webhook event
Check the *Accept Zanata Webhook* checkbox under General section, it will open up more fields.
- The 'URL to register on Zanata' filed is a readonly field for you to register webhook in Zanata. See [Zanata webhook](http://docs.zanata.org/en/release/user-guide/projects/project-settings/#adding-a-new-webhook) for more detail.
- The optional webhook secret for verification of incoming webhooks

### How to use it in pipeline build

#### Use standard push and pull
```groovy
node {
// define common variables
def gitRepo = 'github.com/huangp/test-repo.git'
def gitBranch = 'trans'
def zanataCredentialsId = 'zanata'
def gitCredentialsId = 'huangp_github'
git([url: "https://$gitRepo", branch: gitBranch])
// generated from Pipeline Syntax using general step
step([$class: 'ZanataSyncStep', pullFromZanata: true, pushToZanata: true, zanataCredentialsId: zanataCredentialsId, zanataProjectConfigs: '', zanataLocaleIds: ''])
// copy from https://github.com/jenkinsci/pipeline-examples/blob/master/pipeline-examples/push-git-repo/pushGitRepo.Groovy
withCredentials([[$class: 'UsernamePasswordMultiBinding', credentialsId: gitCredentialsId, usernameVariable: 'GIT_USERNAME', passwordVariable: 'GIT_PASSWORD']]) {
sh('git push https://${GIT_USERNAME}:${GIT_PASSWORD}@' + ' ' + gitRepo)
}
}
```

#### Install tool and run in shell
Assuming a Zanata CLI version 4.0.0 is pre-configured (it will generate a tool name 'zanata_cli_4_0_0').
```groovy
node {
// from Pipeline Syntax: select 'tool: Use a tool from a predefined Tool Installation' and then generate script
tool name: 'zanata_cli_4_0_0', type: 'org.jenkinsci.plugins.zanata.zanatareposync.ZanataCLIInstall'
withEnv(["CLI_HOME=${ tool 'zanata_cli_4_0_0' }"]) {
sh '$CLI_HOME/bin/zanata-cli help'
}
}
```

### Alternative build step (experimental and subject to change without notice)

Yu Shao [email protected]

Find your zanata credential information according to:
http://docs.zanata.org/projects/zanata-client/en/release/configuration/

- Configure your build by selecting 'Zanata Sync via CLI' to use a pre-entered script template

Configure the sync details, there are two sync actions in the plugin, one, pushing the English source file(s) to Zanata server defined in zanata.xml file in the source repo property directories. Two, committing the finished translation files from Zanata to the original Git repository.

Both two types of sync are running the default shell scripts, you could customize the shell scripts, you could customize the two sync actions according to your build need by enabling or disabling them
### User manual
[User manual](http://zanata-jenkins-plugin.readthedocs.io)

0 comments on commit 8fda8ed

Please sign in to comment.