Sha256: 067c3105a0b2406117c19650e0270b2dfa48a0dba033978110b7901e9a2c180c
Contents?: true
Size: 1.94 KB
Versions: 2
Compression:
Stored size: 1.94 KB
Contents
require_relative "../git" require_relative "../github" require_relative "../github/pull_request" require_relative "../scripts" require_relative "../changelog" module Octopolo module Scripts class AcceptPull include Base include GitWrapper include ConfigWrapper include CLIWrapper attr_accessor :pull_request_id def self.execute(pull_request_id) pull_request_id ||= Integer(cli.prompt "Pull Request ID: ") new(pull_request_id).execute end def initialize(pull_request_id) @pull_request_id = pull_request_id end # Public: Perform the script def execute GitHub.connect do pull_request = GitHub::PullRequest.new(config.github_repo, pull_request_id) merge pull_request update_changelog pull_request end rescue GitHub::PullRequest::NotFound cli.say "Unable to find a pull request #{pull_request_id} for #{config.github_repo}. Please verify." end def merge pull_request Git.fetch if pull_request.mergeable? cli.perform "git merge --no-ff origin/#{pull_request.branch} -m \"Merge pull request ##{pull_request_id} from origin/#{pull_request.branch}\"" else cli.say "There is a merge conflict with this branch and #{config.deploy_branch}." cli.say "Please update this branch with #{config.deploy_branch} or perform the merge manually and fix any conflicts" end end def changelog @changelog ||= Changelog.new end def update_changelog pull_request title = pull_request.title authors = pull_request.author_names commenters = pull_request.commenter_names url = pull_request.url changelog.open do |log| log.puts "* #{title}" log.puts log.puts " > #{authors.join(", ")}: #{commenters.join(', ')}: #{url}" log.puts end end end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
octopolo-0.1.0 | lib/octopolo/scripts/accept_pull.rb |
octopolo-0.0.2 | lib/octopolo/scripts/accept_pull.rb |