summaryrefslogtreecommitdiff
path: root/spec/functions/to_bytes_spec.rb
blob: d1ea4c80cc2147c9bcf1a9582f377929a3ae4253 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
#! /usr/bin/env ruby -S rspec

require 'spec_helper'

describe "the to_bytes function" do
  let(:scope) { PuppetlabsSpec::PuppetInternals.scope }

  it "should exist" do
    Puppet::Parser::Functions.function("to_bytes").should == "function_to_bytes"
  end

  it "should raise a ParseError if there is less than 1 arguments" do
    lambda { scope.function_to_bytes([]) }.should( raise_error(Puppet::ParseError))
  end

  it "should convert kB to B" do
    result = scope.function_to_bytes(["4 kB"])
    result.should(eq(4096))
  end

  it "should work without B in unit" do
    result = scope.function_to_bytes(["4 k"])
    result.should(eq(4096))
  end

  it "should work without a space before unit" do
    result = scope.function_to_bytes(["4k"])
    result.should(eq(4096))
  end

  it "should work without a unit" do
    result = scope.function_to_bytes(["5678"])
    result.should(eq(5678))
  end

  it "should convert fractions" do
    result = scope.function_to_bytes(["1.5 kB"])
    result.should(eq(1536))
  end

  it "should convert scientific notation" do
    result = scope.function_to_bytes(["1.5e2 B"])
    result.should(eq(150))
  end

  it "should do nothing with a positive number" do
    result = scope.function_to_bytes([5678])
    result.should(eq(5678))
  end

  it "should should raise a ParseError if input isn't a number" do
    lambda { scope.function_to_bytes(["foo"]) }.should( raise_error(Puppet::ParseError))
  end

  it "should should raise a ParseError if prefix is unknown" do
    lambda { scope.function_to_bytes(["5 uB"]) }.should( raise_error(Puppet::ParseError))
  end
end