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 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144
|
#!/usr/bin/env ruby
require File.expand_path(File.join(File.dirname(__FILE__), "test_helper"))
describe BinData::Base, "parameters" do
it "fails when parameter name is invalid" do
_ {
class InvalidParameterNameBase < BinData::Base
optional_parameter :lazy_eval # from LazyEvaluator
end
}.must_raise NameError
end
it "fails when parameter has nil value" do
_ { BinData::Base.new(a: nil) }.must_raise ArgumentError
end
end
describe BinData::Base, "#has_parameter?" do
it "true for existing parameters" do
obj = BinData::Base.new(a: 3)
assert obj.has_parameter?(:a)
end
it "false for non-existing parameters" do
obj = BinData::Base.new
refute obj.has_parameter?(:a)
end
end
describe BinData::Base, "#get_parameter" do
it "retrieves parameter values" do
obj = BinData::Base.new(a: 3)
_(obj.get_parameter(:a)).must_equal 3
end
it "retrieves parameter values with string keys" do
obj = BinData::Base.new('a' => 3)
_(obj.get_parameter(:a)).must_equal 3
end
it "returns nil for non existing parameters" do
obj = BinData::Base.new
_(obj.get_parameter(:a)).must_be_nil
end
it "wont eval parameters" do
obj = BinData::Base.new(a: -> { 3 })
assert_kind_of Proc, obj.get_parameter(:a)
end
end
describe BinData::Base, "#eval_parameter" do
it "evals the parameter" do
obj = BinData::Base.new(a: -> { 3 })
_(obj.eval_parameter(:a)).must_equal 3
end
it "returns nil for a non existing parameter" do
obj = BinData::Base.new
_(obj.eval_parameter(:a)).must_be_nil
end
end
describe BinData::Base, ".mandatory_parameters" do
class MandatoryBase < BinData::Base
mandatory_parameter :p1
mandatory_parameter :p2
end
it "fails when not all mandatory parameters are present" do
params = {p1: "a", xx: "b" }
_ { MandatoryBase.new(params) }.must_raise ArgumentError
end
it "fails when no mandatory parameters are present" do
_ { MandatoryBase.new() }.must_raise ArgumentError
end
end
describe BinData::Base, ".default_parameters" do
class DefaultBase < BinData::Base
default_parameter p1: "a"
end
it "uses default parameters when not specified" do
obj = DefaultBase.new
_(obj.eval_parameter(:p1)).must_equal "a"
end
it "can override default parameters" do
obj = DefaultBase.new(p1: "b")
_(obj.eval_parameter(:p1)).must_equal "b"
end
end
describe BinData::Base, ".mutually_exclusive_parameters" do
class MutexParamBase < BinData::Base
optional_parameters :p1, :p2, :p3
mutually_exclusive_parameters :p1, :p2, :p3
end
it "fails when any two of those parameters are present" do
_ { MutexParamBase.new(p1: "a", p2: "b") }.must_raise ArgumentError
_ { MutexParamBase.new(p1: "a", p3: "c") }.must_raise ArgumentError
_ { MutexParamBase.new(p2: "b", p3: "c") }.must_raise ArgumentError
end
end
describe BinData::Base, "subclassing" do
class ParamLevel1Base < BinData::Base
optional_parameter :p1
end
class ParamLevel2Base < ParamLevel1Base
optional_parameter :p2
end
it "inherits parameters" do
accepted = ParamLevel2Base.accepted_parameters.all
_(accepted).must_include :p1
_(accepted).must_include :p2
end
end
describe BinData::Base, "subclassing when skipping a level" do
class ParamLevel1Base < BinData::Base
optional_parameter :p1
end
class ParamLevel2Base < ParamLevel1Base
end
class ParamLevel3Base < ParamLevel2Base
optional_parameter :p2
end
it "inherits parameters" do
accepted = ParamLevel3Base.accepted_parameters.all
_(accepted).must_include :p1
_(accepted).must_include :p2
end
end
|