Merge pull request #81 from danzilio/tasks
Adding tasks to automate building GitHub pages from strings docs
This commit is contained in:
commit
57a3bffc47
11
README.md
11
README.md
|
@ -191,7 +191,7 @@ Here are a few other good resources for getting started with documentation:
|
||||||
Rake Tasks
|
Rake Tasks
|
||||||
-----
|
-----
|
||||||
|
|
||||||
This module is also available as a Gem and makes two rake tasks (`strings:generate` and `strings:serve`) available in `puppet-strings/rake_tasks`. To add this to your module's CI workflow, be sure to add this module to your `Gemfile`:
|
This module is also available as a Gem and makes three rake tasks (`strings:generate`, `strings:serve`, and `strings:gh_pages`) available in `puppet-strings/rake_tasks`. To add this to your module's CI workflow, be sure to add this module to your `Gemfile`:
|
||||||
|
|
||||||
In addition to generating the usual 'doc' directory of HTML documentation, the `strings:generate` rake task will also drop a strings.json file containing a JSON representation of the module into the directory the rake task was run from.
|
In addition to generating the usual 'doc' directory of HTML documentation, the `strings:generate` rake task will also drop a strings.json file containing a JSON representation of the module into the directory the rake task was run from.
|
||||||
|
|
||||||
|
@ -219,6 +219,15 @@ PuppetStrings::RakeTasks::Generate.new(:documentation) do |task|
|
||||||
end
|
end
|
||||||
```
|
```
|
||||||
|
|
||||||
|
The `strings:gh_pages` task will generate your Strings documentation to be made available via [GitHub Pages](https://pages.github.com/). It will:
|
||||||
|
|
||||||
|
1. Create a `doc` directory in the root of your project
|
||||||
|
2. Check out the `gh-pages` branch of the current repository in the `doc` directory (it will create a branch if one does not already exist)
|
||||||
|
3. Generate strings documentation using the `strings:generate` task
|
||||||
|
4. Commit the changes and push them to the `gh-pages` branch **with the `-f` flag**
|
||||||
|
|
||||||
|
This task aims to keep the `gh-pages` branch up to date with the current code and uses the `-f` flag when pushing to the `gh-pages` branch. Please keep this in mind as it **will be destructive** if not used properly.
|
||||||
|
|
||||||
Developing and Contributing
|
Developing and Contributing
|
||||||
-----
|
-----
|
||||||
|
|
||||||
|
|
|
@ -15,4 +15,44 @@ namespace :strings do
|
||||||
task :serve do
|
task :serve do
|
||||||
PuppetX::PuppetLabs::Strings::Util.serve
|
PuppetX::PuppetLabs::Strings::Util.serve
|
||||||
end
|
end
|
||||||
|
|
||||||
|
namespace :gh_pages do
|
||||||
|
git_uri = `git config --get remote.origin.url`.strip
|
||||||
|
|
||||||
|
desc "Checkout the gh-pages branch for doc generation."
|
||||||
|
task :checkout do
|
||||||
|
if Dir.exist?('doc')
|
||||||
|
fail "The 'doc' directory (#{File.expand_path('doc')}) is not a Git repository! Remove it and run the Rake task again." unless Dir.exist?('doc/.git')
|
||||||
|
Dir.chdir('doc') do
|
||||||
|
system 'git checkout gh-pages'
|
||||||
|
system 'git reset --hard origin/gh-pages'
|
||||||
|
system 'git pull origin gh-pages'
|
||||||
|
end
|
||||||
|
else
|
||||||
|
Dir.mkdir('doc')
|
||||||
|
Dir.chdir('doc') do
|
||||||
|
system 'git init'
|
||||||
|
system "git remote add origin #{git_uri}"
|
||||||
|
system 'git pull'
|
||||||
|
system 'git checkout -b gh-pages'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
desc "Push new docs to GitHub."
|
||||||
|
task :push do
|
||||||
|
Dir.chdir('doc') do
|
||||||
|
system 'git add .'
|
||||||
|
system "git commit -m '[strings] Generated Documentation Update'"
|
||||||
|
system 'git push origin gh-pages -f'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
desc "Run checkout, generate, and push tasks."
|
||||||
|
task :update => [
|
||||||
|
:checkout,
|
||||||
|
:'strings:generate',
|
||||||
|
:push,
|
||||||
|
]
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue