Class: Danger::Semaphore
Overview
### CI Setup
For Semaphore you will want to go to the settings page of the project. Inside “Build Settings” you should add ‘bundle exec danger` to the Setup thread. Note that Semaphore only provides the build environment variables necessary for Danger on PRs across forks.
### Token Setup
You can add your ‘DANGER_GITHUB_API_TOKEN` inside the “Environment Variables” section in the settings.
Instance Attribute Summary
Attributes inherited from CI
#pull_request_id, #repo_slug, #repo_url
Class Method Summary collapse
Instance Method Summary collapse
-
#initialize(env) ⇒ Semaphore
constructor
A new instance of Semaphore.
- #supported_request_sources ⇒ Object
Methods inherited from CI
available_ci_sources, inherited, #supports?
Constructor Details
#initialize(env) ⇒ Semaphore
Returns a new instance of Semaphore.
28 29 30 31 32 |
# File 'lib/danger/ci_source/semaphore.rb', line 28 def initialize(env) self.repo_slug = env["SEMAPHORE_REPO_SLUG"] self.pull_request_id = env["PULL_REQUEST_NUMBER"] self.repo_url = GitRepo.new.origins # Semaphore doesn't provide a repo url env variable :/ end |
Class Method Details
.validates_as_ci?(env) ⇒ Boolean
16 17 18 |
# File 'lib/danger/ci_source/semaphore.rb', line 16 def self.validates_as_ci?(env) env.key? "SEMAPHORE" end |
.validates_as_pr?(env) ⇒ Boolean
20 21 22 |
# File 'lib/danger/ci_source/semaphore.rb', line 20 def self.validates_as_pr?(env) ["SEMAPHORE_REPO_SLUG", "PULL_REQUEST_NUMBER"].all? { |x| env[x] && !env[x].empty? } end |
Instance Method Details
#supported_request_sources ⇒ Object
24 25 26 |
# File 'lib/danger/ci_source/semaphore.rb', line 24 def supported_request_sources @supported_request_sources ||= [Danger::RequestSources::GitHub] end |