Class: Pipely::Tasks::Definition

Inherits:
Rake::TaskLib
  • Object
show all
Includes:
Rake::DSL
Defined in:
lib/pipely/tasks/definition.rb

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(*args, &task_block) ⇒ Definition

Returns a new instance of Definition.



34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
# File 'lib/pipely/tasks/definition.rb', line 34

def initialize(*args, &task_block)
  setup_ivars(args)

  # First non-name parameter allows overriding the configured scheduler.
  args.unshift(:scheduler)

  directory path

  desc "Generates the pipeline definition file"
  task name, *args do |_, task_args|
    RakeFileUtils.send(:verbose, verbose) do
      if task_block
        task_block.call(*[self, task_args].slice(0, task_block.arity))
      end

      if scheduler_override = task_args[:scheduler]
        definition.config[:scheduler] = scheduler_override
      end

      run_task verbose
    end
  end
end

Instance Attribute Details

#definitionObject

Pipeline definition instance



25
26
27
# File 'lib/pipely/tasks/definition.rb', line 25

def definition
  @definition
end

#nameObject

Name of task.

default:

:definition


16
17
18
# File 'lib/pipely/tasks/definition.rb', line 16

def name
  @name
end

#pathObject

Path where rendered definitions are written.

default:

"definitions"


22
23
24
# File 'lib/pipely/tasks/definition.rb', line 22

def path
  @path
end

#verboseObject

Use verbose output. If this is set to true, the task will print the local and remote paths of each step file it uploads to S3.

default:

true


32
33
34
# File 'lib/pipely/tasks/definition.rb', line 32

def verbose
  @verbose
end

Instance Method Details

#run_task(verbose) ⇒ Object



64
65
66
67
68
69
70
71
72
73
74
75
76
# File 'lib/pipely/tasks/definition.rb', line 64

def run_task(verbose)
  puts "Generating #{target_filename}" if verbose

  json = definition.to_json

  unless ENV['UGLY']
    json = JSON.pretty_generate(JSON.parse(json))
  end

  File.open(target_filename, 'w') do |file|
    file.write(json)
  end
end

#setup_ivars(args) ⇒ Object



58
59
60
61
62
# File 'lib/pipely/tasks/definition.rb', line 58

def setup_ivars(args)
  @name = args.shift || :definition
  @verbose = true
  @path = "definitions"
end

#target_filenameObject



78
79
80
# File 'lib/pipely/tasks/definition.rb', line 78

def target_filename
  "#{path}/#{definition.base_filename}.json"
end