Class: Danger::Semaphore

Inherits:
CI
  • Object
show all
Defined in:
lib/danger/ci_source/semaphore.rb

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

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

Returns:

  • (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

Returns:

  • (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_sourcesObject



24
25
26
# File 'lib/danger/ci_source/semaphore.rb', line 24

def supported_request_sources
  @supported_request_sources ||= [Danger::RequestSources::GitHub]
end