summaryrefslogtreecommitdiff
path: root/spec/lib/puppet_spec/modules.rb
diff options
context:
space:
mode:
authorAshley Penney <ashley.penney@puppetlabs.com>2014-03-18 12:34:40 -0400
committerAshley Penney <ashley.penney@puppetlabs.com>2014-03-18 12:34:40 -0400
commitfec943f441f0c6ab8d6b685091d3418ec0e265b4 (patch)
tree144aed26b9fb50790708c5b221afdeb32bc03186 /spec/lib/puppet_spec/modules.rb
parent326a8fd801ecba11005189c10ca8749872ef6577 (diff)
parent9aa28f1c100d7703aa1bb9fbe2bcf02bf781b486 (diff)
downloadpuppet-stdlib-fec943f441f0c6ab8d6b685091d3418ec0e265b4.tar.gz
puppet-stdlib-fec943f441f0c6ab8d6b685091d3418ec0e265b4.tar.bz2
Merge pull request #231 from apenney/32-testing
Numerous changes to update testing gems.
Diffstat (limited to 'spec/lib/puppet_spec/modules.rb')
-rw-r--r--spec/lib/puppet_spec/modules.rb26
1 files changed, 26 insertions, 0 deletions
diff --git a/spec/lib/puppet_spec/modules.rb b/spec/lib/puppet_spec/modules.rb
new file mode 100644
index 0000000..6835e44
--- /dev/null
+++ b/spec/lib/puppet_spec/modules.rb
@@ -0,0 +1,26 @@
+module PuppetSpec::Modules
+ class << self
+ def create(name, dir, options = {})
+ module_dir = File.join(dir, name)
+ FileUtils.mkdir_p(module_dir)
+
+ environment = options[:environment]
+
+ if metadata = options[:metadata]
+ metadata[:source] ||= 'github'
+ metadata[:author] ||= 'puppetlabs'
+ metadata[:version] ||= '9.9.9'
+ metadata[:license] ||= 'to kill'
+ metadata[:dependencies] ||= []
+
+ metadata[:name] = "#{metadata[:author]}/#{name}"
+
+ File.open(File.join(module_dir, 'metadata.json'), 'w') do |f|
+ f.write(metadata.to_pson)
+ end
+ end
+
+ Puppet::Module.new(name, module_dir, environment)
+ end
+ end
+end