| Age | Commit message (Collapse) | Author | 
|---|
|  | Fix off-by-one error in validate_augeas_spec.rb that was causing rspec failure
Even without the gem installed always, this is helpful to avoid errors should augeas be enabled/installed due to something else. | 
|  | (MODULES-1715) Add FQDN-based random string generator | 
|  |  | 
|  |  | 
|  |  | 
|  | See RFC 1123, Section 2.1
http://tools.ietf.org/html/rfc1123#section-2 | 
|  | Assert private | 
|  |  | 
|  | Dirname typecheck | 
|  | As mentioned in #270, private is a reserved keyword in the future parser
which is to be released with Puppet 4. As it stands, this function is
not useable with the future parser so it needs to renamed.
This is a breaking change. | 
|  | poikilotherm/feature/master/validate_integer_and_numeric
(MODULES-560) Add new functions validate_numeric() and validate_integer(). | 
|  | Signed-off-by: Julien Pivotto <roidelapluie@inuits.eu> | 
|  | The previous commit to uriescape() changed the implementation to use the ruby default escape list for URI.escape(), but did not change the call triggered when uriescape() was called on an array, triggering ruby errors. | 
|  | Add a ceiling function to complement the floor function. | 
|  | only worry if the object responds to upcase | 
|  |  | 
|  | Fix is_domain_name() so it dup's its incoming argument
to avoid changing the original with a later chomp! | 
|  | As per puppetlabs/puppet@292233c, this leaves the global seed in a
deterministic state, which is bad. Puppet::Util.deterministic_rand()
exists to avoid running into this issue, but is only present starting in
Puppet 3.2.0. | 
|  |  | 
|  | The `type()` function will cease to work on the new parser because 'type'
is a reserved keyword. The `type3x()` function may be used to continue
similar functionality, but will be deprecated in favor of the built-in
typing system.
The `type_of()` function has been included to introspect types in the
new parser. | 
|  |  | 
|  | These specs are pretty much the same as the originals, but now check that the output has the correct replacement for file location | 
|  | poikilotherm/feature/master/validate_absolute_path_allow_arrays
Allow array of pathes in validate_absolute_path | 
|  |  | 
|  |  | 
|  |  | 
|  | Also add extra test for just 1 argument | 
|  | `concat` can now take multiple arguments | 
|  |  | 
|  | (MODULES-1329) Allow member to look for array | 
|  | Currently, the member function allows one to only find if a variable
is part of an array. Sometimes it is useful to find if an array is part
of a bigger array for validation purpose. | 
|  |  | 
|  | This is needed for the future parser which actually treats numbers as
numbers and strings as strings. With this patch you can use range(1,5)
instead of having to quote them like range('1','5'). | 
|  | Added correct converstions for PB and EB. | 
|  | * We were converting Exabytes to bytes as Petabytes.
 * Updated tests to cover ever unit.
 * Added note that we're going by the old, inaccurate definitions of
   Kilobytes, Megabytes, etc, in that we treat them as powers of 2. | 
|  | We need to use
  unless value.is_a?(String) || value.is_a?(Array)
rather than
  klass = value.class
  unless [String, Array].include?(klass)
because the klass version enforces type checking which is too strict, and does
not allow us to accept objects wich have extended String (or Array).
For example, generate() function now returns Puppet::Util::Execution::ProcessOutput
which is just a very simple extension of String.  While this in it's self was
not intentional (PUP-2306) it is not unreasonable to cope with objects which
extend Strings | 
|  | It was discovered that the concat array modifies the arrays passed to it
as an argument as a side effect. This test will ensure that doesn't
happen again. | 
|  |  | 
|  | This conversion is done by Transpec 2.2.1 with the following command:
    transpec spec/functions
* 345 conversions
    from: obj.should
      to: expect(obj).to
* 122 conversions
    from: == expected
      to: eq(expected)
* 85 conversions
    from: lambda { }.should
      to: expect { }.to
* 22 conversions
    from: be_true
      to: be_truthy
* 16 conversions
    from: be_false
      to: be_falsey
* 11 conversions
    from: pending
      to: skip
* 9 conversions
    from: it { should ... }
      to: it { is_expected.to ... }
* 5 conversions
    from: =~ [1, 2]
      to: match_array([1, 2])
* 2 conversions
    from: =~ /pattern/
      to: match(/pattern/)
* 2 conversions
    from: obj.should_not
      to: expect(obj).not_to
For more details: https://github.com/yujinakayama/transpec#supported-conversions | 
|  | rspec-puppet matchers are defined for tests which exist in
spec/functions, but the function unit tests lived in
spec/unit/puppet/parser/functions. This moves them to the correct place
for using rspec-puppet | 
|  |  | 
|  | complaining loudly | 
|  | Without this patch one can not specify package resource specific
parameters. All the ensure_packages() function does it makes sure
the named packages are installed. This patch allows one to pass
default as a second argument and allow greater flexibility on
packages installations.
Use case like the following are now possible :
  * ensure_packages(['r10k', 'serverspec'], {'provider' => 'gem'})
  * ensure_packages(['ntp'], {'require' => 'Exec[foobar]'}) | 
|  | This work updates a number of Gems to the latest versions (rspec,
rspec-puppet), and updates and tweaks a bunch of tests to work
with the updated gems. | 
|  | The previous behavior of the tests checked the behavior of the
underlying functions library when called with no arguments; this commit
updates the tests to conform to the functions API and test what happens
when a function is called with no args. | 
|  |  | 
|  | Without this patch the stdlib spec tests are failing against recent
versions of Puppet.  The root cause of this problem is a change in the
behavior of create_resources in Puppet 6baa57b.  The change in behavior
caused the :name key to be omitted from the hash returned by
Puppet::Parser::Resource#to_hash which in turn is causing the test
failure.
This patch addresses the problem by updating the test to match the
description of the example.  Only the attribute :ensure is checked
instead of the full hash itself. | 
|  | This splits out the ensure_resource expectations into separate
blocks for clarity.  Per adrienthebo's recommendation. | 
|  | ensure_resource function
This patch allows an array of resource titles to be passed into
the ensure_resource function.  Each item in the array will be
checked for existence and will be created if it doesn't already
exist. | 
|  | As far as i know there's no other puppet-dsl-like way to get parameter of
defined resource, so that's why i implemented getparam function, which takes
resource reference and parameter name and returns parameter value.
    Here's another example why this function is really useful:
    define config($path, $config_param1, $config_param2) { }
    define example_resource($config) {
        $path = getparam($config, "path")
        notice("Path is $path")
    }
    define example_resource2($example_resource, $config = getparam($example_resource, "config")) {
        $config_param1 = getparam($config, "config_param1")
        notice("Config parameter is $config_param1")
    }
    define example_resource3($example_resource, $config = getparam($example_resource, "config")) {
        $config_param2 = getparam($config, "config_param2")
        notice("Config parameter is $config_param2")
    }
    class test_getparam {
        config { "config_instance":
            path => "/some/config/path",
            config_param1 => "someconfigtext1",
            config_param2 => "someconfigtext2",
        }
        example_resource { "example_resource_instance":
            config => Config["config_instance"]
        }
        example_resource2 { "example_resource_instance":
            example_resource => Example_resource["example_resource_instance"]
        }
        example_resource3 { "example_resource_instance":
            example_resource => Example_resource2["example_resource_instance"]
        }
    }
    class { "test_getparam": } |