Class: Gush::Workflow

Inherits:
Object
  • Object
show all
Defined in:
lib/gush/workflow.rb

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(*args) ⇒ Workflow

Returns a new instance of Workflow.



7
8
9
10
11
12
13
14
15
16
# File 'lib/gush/workflow.rb', line 7

def initialize(*args)
  @id = id
  @jobs = []
  @dependencies = []
  @persisted = false
  @stopped = false
  @arguments = args

  setup
end

Instance Attribute Details

#argumentsObject

Returns the value of attribute arguments.



5
6
7
# File 'lib/gush/workflow.rb', line 5

def arguments
  @arguments
end

#idObject

Returns the value of attribute id.



5
6
7
# File 'lib/gush/workflow.rb', line 5

def id
  @id
end

#jobsObject

Returns the value of attribute jobs.



5
6
7
# File 'lib/gush/workflow.rb', line 5

def jobs
  @jobs
end

#persistedObject

Returns the value of attribute persisted.



5
6
7
# File 'lib/gush/workflow.rb', line 5

def persisted
  @persisted
end

#stoppedObject

Returns the value of attribute stopped.



5
6
7
# File 'lib/gush/workflow.rb', line 5

def stopped
  @stopped
end

Class Method Details

.create(*args) ⇒ Object



22
23
24
25
26
# File 'lib/gush/workflow.rb', line 22

def self.create(*args)
  flow = new(*args)
  flow.save
  flow
end

.descendantsObject



179
180
181
# File 'lib/gush/workflow.rb', line 179

def self.descendants
  ObjectSpace.each_object(Class).select { |klass| klass < self }
end

.find(id) ⇒ Object



18
19
20
# File 'lib/gush/workflow.rb', line 18

def self.find(id)
  Gush::Client.new.find_workflow(id)
end

Instance Method Details

#configure(*args) ⇒ Object



41
42
# File 'lib/gush/workflow.rb', line 41

def configure(*args)
end

#continueObject



28
29
30
31
32
33
34
35
# File 'lib/gush/workflow.rb', line 28

def continue
  client = Gush::Client.new
  failed_jobs = jobs.select(&:failed?)

  failed_jobs.each do |job|
    client.enqueue_job(id, job)
  end
end

#failed?Boolean

Returns:

  • (Boolean)


96
97
98
# File 'lib/gush/workflow.rb', line 96

def failed?
  jobs.any?(&:failed?)
end

#find_job(name) ⇒ Object



74
75
76
77
78
79
80
81
82
# File 'lib/gush/workflow.rb', line 74

def find_job(name)
  match_data = /(?<klass>\w*[^-])-(?<identifier>.*)/.match(name.to_s)
  if match_data.nil?
    job = jobs.find { |node| node.class.to_s == name.to_s }
  else
    job = jobs.find { |node| node.name.to_s == name.to_s }
  end
  job
end

#finished?Boolean

Returns:

  • (Boolean)


84
85
86
# File 'lib/gush/workflow.rb', line 84

def finished?
  jobs.all?(&:finished?)
end

#finished_atObject



154
155
156
# File 'lib/gush/workflow.rb', line 154

def finished_at
  last_job ? last_job.finished_at : nil
end

#initial_jobsObject



131
132
133
# File 'lib/gush/workflow.rb', line 131

def initial_jobs
  jobs.select(&:has_no_dependencies?)
end

#mark_as_persistedObject



56
57
58
# File 'lib/gush/workflow.rb', line 56

def mark_as_persisted
  @persisted = true
end

#mark_as_startedObject



60
61
62
# File 'lib/gush/workflow.rb', line 60

def mark_as_started
  @stopped = false
end

#mark_as_stoppedObject



44
45
46
# File 'lib/gush/workflow.rb', line 44

def mark_as_stopped
  @stopped = true
end

#persist!Object



52
53
54
# File 'lib/gush/workflow.rb', line 52

def persist!
  client.persist_workflow(self)
end

#reloadObject



127
128
129
# File 'lib/gush/workflow.rb', line 127

def reload
  self.class.find(id)
end

#resolve_dependenciesObject



64
65
66
67
68
69
70
71
72
# File 'lib/gush/workflow.rb', line 64

def resolve_dependencies
  @dependencies.each do |dependency|
    from = find_job(dependency[:from])
    to   = find_job(dependency[:to])

    to.incoming << dependency[:from]
    from.outgoing << dependency[:to]
  end
end

#run(klass, opts = {}) ⇒ Object



104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
# File 'lib/gush/workflow.rb', line 104

def run(klass, opts = {})
  options =

  node = klass.new(self, {
    name: client.next_free_job_id(id,klass.to_s),
    params: opts.fetch(:params, {})
  })

  jobs << node

  deps_after = [*opts[:after]]
  deps_after.each do |dep|
    @dependencies << {from: dep.to_s, to: node.name.to_s }
  end

  deps_before = [*opts[:before]]
  deps_before.each do |dep|
    @dependencies << {from: node.name.to_s, to: dep.to_s }
  end

  node.name
end

#running?Boolean

Returns:

  • (Boolean)


92
93
94
# File 'lib/gush/workflow.rb', line 92

def running?
  started? && !finished?
end

#saveObject



37
38
39
# File 'lib/gush/workflow.rb', line 37

def save
  persist!
end

#start!Object



48
49
50
# File 'lib/gush/workflow.rb', line 48

def start!
  client.start_workflow(self)
end

#started?Boolean

Returns:

  • (Boolean)


88
89
90
# File 'lib/gush/workflow.rb', line 88

def started?
  !!started_at
end

#started_atObject



150
151
152
# File 'lib/gush/workflow.rb', line 150

def started_at
  first_job ? first_job.started_at : nil
end

#statusObject



135
136
137
138
139
140
141
142
143
144
145
146
147
148
# File 'lib/gush/workflow.rb', line 135

def status
  case
    when failed?
      :failed
    when running?
      :running
    when finished?
      :finished
    when stopped?
      :stopped
    else
      :running
  end
end

#stopped?Boolean

Returns:

  • (Boolean)


100
101
102
# File 'lib/gush/workflow.rb', line 100

def stopped?
  stopped
end

#to_hashObject



158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
# File 'lib/gush/workflow.rb', line 158

def to_hash
  name = self.class.to_s
  {
    name: name,
    id: id,
    arguments: @arguments,
    total: jobs.count,
    finished: jobs.count(&:finished?),
    klass: name,
    jobs: jobs.map(&:as_json),
    status: status,
    stopped: stopped,
    started_at: started_at,
    finished_at: finished_at
  }
end

#to_json(options = {}) ⇒ Object



175
176
177
# File 'lib/gush/workflow.rb', line 175

def to_json(options = {})
  Gush::JSON.encode(to_hash)
end