Add support for arrays to PluginStore

This commit is contained in:
Benjamin Kampmann 2014-03-10 10:22:59 +01:00
parent c5beb3852f
commit 680197200e
2 changed files with 40 additions and 2 deletions

View File

@ -31,14 +31,24 @@ class PluginStore
def self.determine_type(value) def self.determine_type(value)
value.is_a?(Hash) ? "JSON" : value.class.to_s value.is_a?(Hash) || value.is_a?(Array) ? "JSON" : value.class.to_s
end
def self.map_json(item)
if item.is_a? Hash
ActiveSupport::HashWithIndifferentAccess.new item
elsif item.is_a? Array
item.map { |subitem| map_json subitem}
else
item
end
end end
def self.cast_value(type, value) def self.cast_value(type, value)
case type case type
when "Fixnum" then value.to_i when "Fixnum" then value.to_i
when "TrueClass", "FalseClass" then value == "true" when "TrueClass", "FalseClass" then value == "true"
when "JSON" then ActiveSupport::HashWithIndifferentAccess.new(::JSON.parse(value)) when "JSON" then map_json(::JSON.parse(value))
else value else value
end end
end end

View File

@ -51,6 +51,34 @@ describe PluginStore do
expect(result[:hi]).to eq("there") expect(result[:hi]).to eq("there")
end end
it "handles nested hashes correctly" do
val = {"hi" => "there", "nested" => {"a" => "b", "with list" => ["a", "b", 3] }}
set("hello", val)
result = get("hello")
expect(result).to eq(val)
# ensure indiff access holds
expect(result[:hi]).to eq("there")
expect(result[:nested][:a]).to eq("b")
expect(result[:nested]["with list"]).to eq(["a", "b", 3])
end
it "handles arrays correctly" do
val = ["a", "b", {"hash"=> "inside", "c"=> 1}]
set("hello", val)
result = get("hello")
expect(result).to eq(val)
# ensure indiff access holds
expect(result[2][:hash]).to eq("inside")
expect(result[2]["c"]).to eq(1)
end
it "removes correctly" do it "removes correctly" do
set("hello", true) set("hello", true)
remove_row("hello") remove_row("hello")