deployflow 0.0.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
data/.document ADDED
@@ -0,0 +1,5 @@
1
+ lib/**/*.rb
2
+ bin/*
3
+ -
4
+ features/**/*.feature
5
+ LICENSE.txt
data/Gemfile ADDED
@@ -0,0 +1,15 @@
1
+ source "http://rubygems.org"
2
+ # Add dependencies required to use your gem here.
3
+ # Example:
4
+ # gem "activesupport", ">= 2.3.5"
5
+ gem "capistrano"
6
+ gem "capistrano-ext"
7
+
8
+ # Add dependencies to develop your gem here.
9
+ # Include everything needed to run rake, tests, features, etc.
10
+ group :development do
11
+ gem "shoulda", ">= 0"
12
+ gem "bundler", "~> 1.0.0"
13
+ gem "jeweler", "~> 1.6.0"
14
+ gem "rcov", ">= 0"
15
+ end
data/Gemfile.lock ADDED
@@ -0,0 +1,38 @@
1
+ GEM
2
+ remote: http://rubygems.org/
3
+ specs:
4
+ capistrano (2.6.0)
5
+ highline
6
+ net-scp (>= 1.0.0)
7
+ net-sftp (>= 2.0.0)
8
+ net-ssh (>= 2.0.14)
9
+ net-ssh-gateway (>= 1.1.0)
10
+ capistrano-ext (1.2.1)
11
+ capistrano (>= 1.0.0)
12
+ git (1.2.5)
13
+ highline (1.6.2)
14
+ jeweler (1.6.0)
15
+ bundler (~> 1.0.0)
16
+ git (>= 1.2.5)
17
+ rake
18
+ net-scp (1.0.4)
19
+ net-ssh (>= 1.99.1)
20
+ net-sftp (2.0.5)
21
+ net-ssh (>= 2.0.9)
22
+ net-ssh (2.1.4)
23
+ net-ssh-gateway (1.1.0)
24
+ net-ssh (>= 1.99.1)
25
+ rake (0.9.0)
26
+ rcov (0.9.9)
27
+ shoulda (2.11.3)
28
+
29
+ PLATFORMS
30
+ ruby
31
+
32
+ DEPENDENCIES
33
+ bundler (~> 1.0.0)
34
+ capistrano
35
+ capistrano-ext
36
+ jeweler (~> 1.6.0)
37
+ rcov
38
+ shoulda
data/LICENSE.txt ADDED
@@ -0,0 +1,20 @@
1
+ Copyright (c) 2011 Nickolas Means
2
+
3
+ Permission is hereby granted, free of charge, to any person obtaining
4
+ a copy of this software and associated documentation files (the
5
+ "Software"), to deal in the Software without restriction, including
6
+ without limitation the rights to use, copy, modify, merge, publish,
7
+ distribute, sublicense, and/or sell copies of the Software, and to
8
+ permit persons to whom the Software is furnished to do so, subject to
9
+ the following conditions:
10
+
11
+ The above copyright notice and this permission notice shall be
12
+ included in all copies or substantial portions of the Software.
13
+
14
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
15
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
17
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
18
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
19
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
20
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
data/README.markdown ADDED
@@ -0,0 +1,73 @@
1
+ deployflow
2
+ ==========
3
+
4
+ deployflow lets you use git-flow to release into a 'staging' branch and then promote specific
5
+ tags into your 'master' branch for deploying to production. It's for those of us who are
6
+ persnickety about keeping master as a canonical repository of what's actually running in
7
+ production and doing all our mucking about elsewhere.
8
+
9
+ Installation
10
+ ------------
11
+
12
+ 1. git-flow
13
+
14
+ I'd recommend you use my custom fork of git-flow with deployflow. It adds
15
+ version number auto-incrementation and suppresses the need to add a message
16
+ to each tag you create. You can install it by:
17
+
18
+ `brew uninstall git-flow` (if you've previously installed git-flow via Homebrew)
19
+ `git clone --recursive git://github.com/nmeans/gitflow.git`
20
+ `cd gitflow`
21
+ `make install` (or `sudo make install` if you don't own `/usr/local/bin`)
22
+
23
+ If you'd prefer the original, visit [http://github.com/nvie/gitflow](http://github.com/nvie/gitflow)
24
+ for install information.
25
+
26
+ 2. Capistrano Multistage
27
+
28
+ `gem install capistrano-ext`
29
+
30
+ 3. deployflow
31
+
32
+ It's as simple as:
33
+ `gem install deployflow`
34
+
35
+ Repository Setup
36
+ ----------------
37
+
38
+ 1. Add a few branches to your repo
39
+
40
+ If you don't already have them, you'll need to add `develop` and `staging` branches. You should have a `master` branch by default.
41
+
42
+ 2. Run git flow init on your repo
43
+
44
+ You'll want to use `staging` as your branch for production releases and `develop` for next release development
45
+
46
+ 3. Add the following to the top of your config/deploy.rb
47
+
48
+ require 'capistrano/ext/multistage'
49
+ require 'capistrano/deployflow'
50
+
51
+ Usage
52
+ -----
53
+
54
+ Just use git-flow like normal. Create a release you want to deploy with `git flow release` or `git flow hotfix`.
55
+
56
+ When you're ready to deploy your release to staging, no need to push first, just run `cap staging deploy` and
57
+ deployflow will automatically push to origin and deploy your most recent tag to staging.
58
+
59
+ After you've tested in staging, you're ready to promote your tag to master and roll it out to production. All
60
+ you have to do is `cap production deploy`, and deployflow will ask which tag you'd like to promote (suggesting
61
+ your most recent automatically), merge that tag over to your master branch, push to origin, and deploy the head
62
+ of your master branch to production.
63
+
64
+ Credits
65
+ -------
66
+
67
+ Heavily inspired by Josh Nichols' [capistrano-gitflow](https://github.com/technicalpickles/capistrano-gitflow)
68
+
69
+ Copyright
70
+ ---------
71
+
72
+ Copyright (c) 2011 Nickolas Means. See LICENSE.txt for
73
+ further details.
data/Rakefile ADDED
@@ -0,0 +1,26 @@
1
+ # encoding: utf-8
2
+
3
+ require 'rubygems'
4
+ require 'bundler'
5
+ begin
6
+ Bundler.setup(:default, :development)
7
+ rescue Bundler::BundlerError => e
8
+ $stderr.puts e.message
9
+ $stderr.puts "Run `bundle install` to install missing gems"
10
+ exit e.status_code
11
+ end
12
+ require 'rake'
13
+
14
+ require 'jeweler'
15
+ Jeweler::Tasks.new do |gem|
16
+ # gem is a Gem::Specification... see http://docs.rubygems.org/read/chapter/20 for more options
17
+ gem.name = "deployflow"
18
+ gem.homepage = "http://github.com/nmeans/deployflow"
19
+ gem.license = "MIT"
20
+ gem.summary = %Q{Quiet multistage versioning/deployment strategy using git-flow and capistrano-multistage}
21
+ gem.description = %Q{Quiet multistage versioning/deployment strategy using git-flow and capistrano-multistage}
22
+ gem.email = "nick@activeprospect.com"
23
+ gem.authors = ["Nickolas Means"]
24
+ # dependencies defined in Gemfile
25
+ end
26
+ Jeweler::RubygemsDotOrgTasks.new
data/VERSION ADDED
@@ -0,0 +1 @@
1
+ 0.0.3
@@ -0,0 +1,65 @@
1
+ # Generated by jeweler
2
+ # DO NOT EDIT THIS FILE DIRECTLY
3
+ # Instead, edit Jeweler::Tasks in Rakefile, and run 'rake gemspec'
4
+ # -*- encoding: utf-8 -*-
5
+
6
+ Gem::Specification.new do |s|
7
+ s.name = %q{deployflow}
8
+ s.version = "0.0.3"
9
+
10
+ s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
11
+ s.authors = ["Nickolas Means"]
12
+ s.date = %q{2011-05-26}
13
+ s.description = %q{Quiet multistage versioning/deployment strategy using git-flow and capistrano-multistage}
14
+ s.email = %q{nick@activeprospect.com}
15
+ s.extra_rdoc_files = [
16
+ "LICENSE.txt",
17
+ "README.markdown"
18
+ ]
19
+ s.files = [
20
+ ".document",
21
+ "Gemfile",
22
+ "Gemfile.lock",
23
+ "LICENSE.txt",
24
+ "README.markdown",
25
+ "Rakefile",
26
+ "VERSION",
27
+ "deployflow.gemspec",
28
+ "lib/capistrano/deployflow.rb",
29
+ "test/helper.rb",
30
+ "test/test_deployflow.rb"
31
+ ]
32
+ s.homepage = %q{http://github.com/nmeans/deployflow}
33
+ s.licenses = ["MIT"]
34
+ s.require_paths = ["lib"]
35
+ s.rubygems_version = %q{1.6.2}
36
+ s.summary = %q{Quiet multistage versioning/deployment strategy using git-flow and capistrano-multistage}
37
+
38
+ if s.respond_to? :specification_version then
39
+ s.specification_version = 3
40
+
41
+ if Gem::Version.new(Gem::VERSION) >= Gem::Version.new('1.2.0') then
42
+ s.add_runtime_dependency(%q<capistrano>, [">= 0"])
43
+ s.add_runtime_dependency(%q<capistrano-ext>, [">= 0"])
44
+ s.add_development_dependency(%q<shoulda>, [">= 0"])
45
+ s.add_development_dependency(%q<bundler>, ["~> 1.0.0"])
46
+ s.add_development_dependency(%q<jeweler>, ["~> 1.6.0"])
47
+ s.add_development_dependency(%q<rcov>, [">= 0"])
48
+ else
49
+ s.add_dependency(%q<capistrano>, [">= 0"])
50
+ s.add_dependency(%q<capistrano-ext>, [">= 0"])
51
+ s.add_dependency(%q<shoulda>, [">= 0"])
52
+ s.add_dependency(%q<bundler>, ["~> 1.0.0"])
53
+ s.add_dependency(%q<jeweler>, ["~> 1.6.0"])
54
+ s.add_dependency(%q<rcov>, [">= 0"])
55
+ end
56
+ else
57
+ s.add_dependency(%q<capistrano>, [">= 0"])
58
+ s.add_dependency(%q<capistrano-ext>, [">= 0"])
59
+ s.add_dependency(%q<shoulda>, [">= 0"])
60
+ s.add_dependency(%q<bundler>, ["~> 1.0.0"])
61
+ s.add_dependency(%q<jeweler>, ["~> 1.6.0"])
62
+ s.add_dependency(%q<rcov>, [">= 0"])
63
+ end
64
+ end
65
+
@@ -0,0 +1,84 @@
1
+ require 'capistrano'
2
+
3
+ module Capistrano
4
+ class Deployflow
5
+ def self.load_into(capistrano_configuration)
6
+ capistrano_configuration.load do
7
+ before "deploy:update_code", "deployflow:set_deploy_codebase"
8
+ before "deployflow:set_deploy_codebase", "deployflow:verify_up_to_date"
9
+
10
+ namespace :deployflow do
11
+
12
+ def most_recent_tag
13
+ `git for-each-ref --sort='*authordate' --format='%(refname:short)' refs/tags | sed '$!d'`.chomp
14
+ end
15
+
16
+ def ask_which_tag
17
+ tag = Capistrano::CLI.ui.ask("What tag would you like to promote to #{stage}? [#{most_recent_tag}]")
18
+ if tag == ""
19
+ promote_tag = most_recent_tag
20
+ else
21
+ # Do we have this tag?
22
+ abort "Tag '#{tag}' does not exist!" unless `git tag`.split(/\n/).include?(tag)
23
+ promote_tag = tag
24
+ end
25
+ puts "Promoting #{promote_tag} to #{stage}."
26
+ return promote_tag
27
+ end
28
+
29
+ desc "Set the tag to deploy to the selected stage."
30
+ task :set_deploy_codebase do
31
+ abort "Unsupported stage: #{stage}." unless [:staging, :production].include?(stage)
32
+ if stage == :staging
33
+ # Ask which tag to deploy
34
+ tag_to_deploy = ask_which_tag
35
+ # Push to origin staging
36
+ system "git push --tags origin staging"
37
+ abort "Git push failed!" if $? != 0
38
+ # Set deploy codebase to our tag
39
+ set :branch, tag_to_deploy
40
+ elsif stage == :production
41
+ tag_to_deploy = ask_which_tag
42
+ # Switch to 'master'
43
+ system "git checkout master"
44
+ abort "Could not switch to 'master' branch!" if $? != 0
45
+ # Merge select tag into master
46
+ system "git merge --no-ff #{tag_to_deploy}"
47
+ abort "Could not merge tag '#{tag_to_deploy}' into master!" if $? != 0
48
+ # Push to origin master
49
+ system "git push --tags origin master"
50
+ abort "Git push failed!" if $? != 0
51
+ # Set our deploy codebase to our tag
52
+ system "git checkout develop"
53
+ puts "*** Could not switch back to 'develop' branch! Be sure to manually switch before continuing work." if $? != 0
54
+ set :branch, tag_to_deploy
55
+ end
56
+
57
+ end
58
+
59
+ task :verify_up_to_date do
60
+ set :local_branch, `git branch --no-color 2> /dev/null | sed -e '/^[^*]/d'`.gsub(/\* /, '').chomp
61
+ set :local_sha, `git log --pretty=format:%H HEAD -1`.chomp
62
+ set :origin_sha, `git log --pretty=format:%H #{local_branch} -1`
63
+ unless local_sha == origin_sha
64
+ abort """
65
+ Your #{local_branch} branch is not up to date with origin/#{local_branch}.
66
+ Please make sure you have pulled and pushed all code before deploying:
67
+
68
+ git pull origin #{local_branch}
69
+ # run tests, etc
70
+ git push origin #{local_branch}
71
+
72
+ """
73
+ end
74
+ end
75
+
76
+ end
77
+ end
78
+ end
79
+ end
80
+ end
81
+
82
+ if Capistrano::Configuration.instance
83
+ Capistrano::Deployflow.load_into(Capistrano::Configuration.instance)
84
+ end
data/test/helper.rb ADDED
@@ -0,0 +1,18 @@
1
+ require 'rubygems'
2
+ require 'bundler'
3
+ begin
4
+ Bundler.setup(:default, :development)
5
+ rescue Bundler::BundlerError => e
6
+ $stderr.puts e.message
7
+ $stderr.puts "Run `bundle install` to install missing gems"
8
+ exit e.status_code
9
+ end
10
+ require 'test/unit'
11
+ require 'shoulda'
12
+
13
+ $LOAD_PATH.unshift(File.join(File.dirname(__FILE__), '..', 'lib'))
14
+ $LOAD_PATH.unshift(File.dirname(__FILE__))
15
+ require 'deployflow'
16
+
17
+ class Test::Unit::TestCase
18
+ end
@@ -0,0 +1,7 @@
1
+ require 'helper'
2
+
3
+ class TestDeployflow < Test::Unit::TestCase
4
+ should "probably rename this file and start testing for real" do
5
+ flunk "hey buddy, you should probably rename this file and start testing for real"
6
+ end
7
+ end
metadata ADDED
@@ -0,0 +1,135 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: deployflow
3
+ version: !ruby/object:Gem::Version
4
+ prerelease:
5
+ version: 0.0.3
6
+ platform: ruby
7
+ authors:
8
+ - Nickolas Means
9
+ autorequire:
10
+ bindir: bin
11
+ cert_chain: []
12
+
13
+ date: 2011-05-26 00:00:00 -05:00
14
+ default_executable:
15
+ dependencies:
16
+ - !ruby/object:Gem::Dependency
17
+ name: capistrano
18
+ requirement: &id001 !ruby/object:Gem::Requirement
19
+ none: false
20
+ requirements:
21
+ - - ">="
22
+ - !ruby/object:Gem::Version
23
+ version: "0"
24
+ type: :runtime
25
+ prerelease: false
26
+ version_requirements: *id001
27
+ - !ruby/object:Gem::Dependency
28
+ name: capistrano-ext
29
+ requirement: &id002 !ruby/object:Gem::Requirement
30
+ none: false
31
+ requirements:
32
+ - - ">="
33
+ - !ruby/object:Gem::Version
34
+ version: "0"
35
+ type: :runtime
36
+ prerelease: false
37
+ version_requirements: *id002
38
+ - !ruby/object:Gem::Dependency
39
+ name: shoulda
40
+ requirement: &id003 !ruby/object:Gem::Requirement
41
+ none: false
42
+ requirements:
43
+ - - ">="
44
+ - !ruby/object:Gem::Version
45
+ version: "0"
46
+ type: :development
47
+ prerelease: false
48
+ version_requirements: *id003
49
+ - !ruby/object:Gem::Dependency
50
+ name: bundler
51
+ requirement: &id004 !ruby/object:Gem::Requirement
52
+ none: false
53
+ requirements:
54
+ - - ~>
55
+ - !ruby/object:Gem::Version
56
+ version: 1.0.0
57
+ type: :development
58
+ prerelease: false
59
+ version_requirements: *id004
60
+ - !ruby/object:Gem::Dependency
61
+ name: jeweler
62
+ requirement: &id005 !ruby/object:Gem::Requirement
63
+ none: false
64
+ requirements:
65
+ - - ~>
66
+ - !ruby/object:Gem::Version
67
+ version: 1.6.0
68
+ type: :development
69
+ prerelease: false
70
+ version_requirements: *id005
71
+ - !ruby/object:Gem::Dependency
72
+ name: rcov
73
+ requirement: &id006 !ruby/object:Gem::Requirement
74
+ none: false
75
+ requirements:
76
+ - - ">="
77
+ - !ruby/object:Gem::Version
78
+ version: "0"
79
+ type: :development
80
+ prerelease: false
81
+ version_requirements: *id006
82
+ description: Quiet multistage versioning/deployment strategy using git-flow and capistrano-multistage
83
+ email: nick@activeprospect.com
84
+ executables: []
85
+
86
+ extensions: []
87
+
88
+ extra_rdoc_files:
89
+ - LICENSE.txt
90
+ - README.markdown
91
+ files:
92
+ - .document
93
+ - Gemfile
94
+ - Gemfile.lock
95
+ - LICENSE.txt
96
+ - README.markdown
97
+ - Rakefile
98
+ - VERSION
99
+ - deployflow.gemspec
100
+ - lib/capistrano/deployflow.rb
101
+ - test/helper.rb
102
+ - test/test_deployflow.rb
103
+ has_rdoc: true
104
+ homepage: http://github.com/nmeans/deployflow
105
+ licenses:
106
+ - MIT
107
+ post_install_message:
108
+ rdoc_options: []
109
+
110
+ require_paths:
111
+ - lib
112
+ required_ruby_version: !ruby/object:Gem::Requirement
113
+ none: false
114
+ requirements:
115
+ - - ">="
116
+ - !ruby/object:Gem::Version
117
+ hash: -3863862650389113681
118
+ segments:
119
+ - 0
120
+ version: "0"
121
+ required_rubygems_version: !ruby/object:Gem::Requirement
122
+ none: false
123
+ requirements:
124
+ - - ">="
125
+ - !ruby/object:Gem::Version
126
+ version: "0"
127
+ requirements: []
128
+
129
+ rubyforge_project:
130
+ rubygems_version: 1.6.2
131
+ signing_key:
132
+ specification_version: 3
133
+ summary: Quiet multistage versioning/deployment strategy using git-flow and capistrano-multistage
134
+ test_files: []
135
+