mirror of
https://github.com/kemko/liquid.git
synced 2026-01-02 08:15:41 +03:00
Compare commits
4 Commits
static_reg
...
remove-jru
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
cf5a42245f | ||
|
|
ca207ed93f | ||
|
|
ef13343591 | ||
|
|
adb40c41b7 |
@@ -1,5 +1,5 @@
|
|||||||
inherit_from:
|
inherit_from:
|
||||||
- https://shopify.github.io/ruby-style-guide/rubocop.yml
|
- 'https://shopify.github.io/ruby-style-guide/rubocop.yml'
|
||||||
- .rubocop_todo.yml
|
- .rubocop_todo.yml
|
||||||
|
|
||||||
require: rubocop-performance
|
require: rubocop-performance
|
||||||
@@ -10,7 +10,7 @@ Performance:
|
|||||||
AllCops:
|
AllCops:
|
||||||
Exclude:
|
Exclude:
|
||||||
- 'vendor/bundle/**/*'
|
- 'vendor/bundle/**/*'
|
||||||
|
|
||||||
Naming/MethodName:
|
Naming/MethodName:
|
||||||
Exclude:
|
Exclude:
|
||||||
- 'example/server/liquid_servlet.rb'
|
- 'example/server/liquid_servlet.rb'
|
||||||
|
|||||||
@@ -7,8 +7,6 @@ rvm:
|
|||||||
- &latest_ruby 2.6
|
- &latest_ruby 2.6
|
||||||
- 2.7
|
- 2.7
|
||||||
- ruby-head
|
- ruby-head
|
||||||
- jruby-head
|
|
||||||
- truffleruby
|
|
||||||
|
|
||||||
matrix:
|
matrix:
|
||||||
include:
|
include:
|
||||||
@@ -17,8 +15,6 @@ matrix:
|
|||||||
name: Profiling Memory Usage
|
name: Profiling Memory Usage
|
||||||
allow_failures:
|
allow_failures:
|
||||||
- rvm: ruby-head
|
- rvm: ruby-head
|
||||||
- rvm: jruby-head
|
|
||||||
- rvm: truffleruby
|
|
||||||
|
|
||||||
branches:
|
branches:
|
||||||
only:
|
only:
|
||||||
|
|||||||
@@ -1,9 +1,11 @@
|
|||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
module Liquid
|
module Liquid
|
||||||
class StaticRegisters
|
class StaticRegisters
|
||||||
attr_reader :static_registers, :registers
|
attr_reader :static, :registers
|
||||||
|
|
||||||
def initialize(registers = {})
|
def initialize(registers = {})
|
||||||
@static_registers = registers.is_a?(StaticRegisters) ? registers.static_registers : registers.freeze
|
@static = registers.is_a?(StaticRegisters) ? registers.static : registers
|
||||||
@registers = {}
|
@registers = {}
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -15,7 +17,7 @@ module Liquid
|
|||||||
if @registers.key?(key)
|
if @registers.key?(key)
|
||||||
@registers[key]
|
@registers[key]
|
||||||
else
|
else
|
||||||
@static_registers[key]
|
@static[key]
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -28,7 +30,7 @@ module Liquid
|
|||||||
end
|
end
|
||||||
|
|
||||||
def key?(key)
|
def key?(key)
|
||||||
@registers.key?(key) || @static_registers.key?(key)
|
@registers.key?(key) || @static.key?(key)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -1,3 +1,5 @@
|
|||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
require 'test_helper'
|
require 'test_helper'
|
||||||
|
|
||||||
class StaticRegistersUnitTest < Minitest::Test
|
class StaticRegistersUnitTest < Minitest::Test
|
||||||
@@ -80,7 +82,7 @@ class StaticRegistersUnitTest < Minitest::Test
|
|||||||
static_register["two"] = 4
|
static_register["two"] = 4
|
||||||
static_register[true] = "foo"
|
static_register[true] = "foo"
|
||||||
|
|
||||||
assert_equal({ nil => true, 1 => :one, :one => "one", "two" => 3, false => nil }, static_register.static_registers)
|
assert_equal({ nil => true, 1 => :one, :one => "one", "two" => 3, false => nil }, static_register.static)
|
||||||
assert_equal({ nil => false, "two" => 4, true => "foo" }, static_register.registers)
|
assert_equal({ nil => false, "two" => 4, true => "foo" }, static_register.registers)
|
||||||
|
|
||||||
static_register
|
static_register
|
||||||
@@ -107,7 +109,7 @@ class StaticRegistersUnitTest < Minitest::Test
|
|||||||
assert_nil static_register.delete(:one)
|
assert_nil static_register.delete(:one)
|
||||||
|
|
||||||
assert_equal({}, static_register.registers)
|
assert_equal({}, static_register.registers)
|
||||||
assert_equal({ nil => true, 1 => :one, :one => "one", "two" => 3, false => nil }, static_register.static_registers)
|
assert_equal({ nil => true, 1 => :one, :one => "one", "two" => 3, false => nil }, static_register.static)
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_fetch_with_static
|
def test_fetch_with_static
|
||||||
@@ -133,10 +135,10 @@ class StaticRegistersUnitTest < Minitest::Test
|
|||||||
assert_equal true, static_register.key?(true)
|
assert_equal true, static_register.key?(true)
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_static_register_frozen
|
def test_static_register_can_be_frozen
|
||||||
static_register = set_with_static
|
static_register = set_with_static
|
||||||
|
|
||||||
static = static_register.static_registers
|
static = static_register.static.freeze
|
||||||
|
|
||||||
assert_raises(RuntimeError) do
|
assert_raises(RuntimeError) do
|
||||||
static["two"] = "foo"
|
static["two"] = "foo"
|
||||||
@@ -174,9 +176,9 @@ class StaticRegistersUnitTest < Minitest::Test
|
|||||||
assert_equal({ "one" => 1, "two" => 2, "three" => 3 }, static_register.registers)
|
assert_equal({ "one" => 1, "two" => 2, "three" => 3 }, static_register.registers)
|
||||||
assert_equal({ "one" => 4, "two" => 5, "three" => 6 }, new_register.registers)
|
assert_equal({ "one" => 4, "two" => 5, "three" => 6 }, new_register.registers)
|
||||||
assert_equal({ "one" => 7, "two" => 8, "three" => 9 }, newest_register.registers)
|
assert_equal({ "one" => 7, "two" => 8, "three" => 9 }, newest_register.registers)
|
||||||
assert_equal({ nil => true, 1 => :one, :one => "one", "two" => 3, false => nil }, static_register.static_registers)
|
assert_equal({ nil => true, 1 => :one, :one => "one", "two" => 3, false => nil }, static_register.static)
|
||||||
assert_equal({ nil => true, 1 => :one, :one => "one", "two" => 3, false => nil }, new_register.static_registers)
|
assert_equal({ nil => true, 1 => :one, :one => "one", "two" => 3, false => nil }, new_register.static)
|
||||||
assert_equal({ nil => true, 1 => :one, :one => "one", "two" => 3, false => nil }, newest_register.static_registers)
|
assert_equal({ nil => true, 1 => :one, :one => "one", "two" => 3, false => nil }, newest_register.static)
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_multiple_instances_are_unique
|
def test_multiple_instances_are_unique
|
||||||
@@ -202,8 +204,45 @@ class StaticRegistersUnitTest < Minitest::Test
|
|||||||
assert_equal({ "one" => 1, "two" => 2, "three" => 3 }, static_register.registers)
|
assert_equal({ "one" => 1, "two" => 2, "three" => 3 }, static_register.registers)
|
||||||
assert_equal({ "one" => 4, "two" => 5, "three" => 6 }, new_register.registers)
|
assert_equal({ "one" => 4, "two" => 5, "three" => 6 }, new_register.registers)
|
||||||
assert_equal({ "one" => 7, "two" => 8, "three" => 9 }, newest_register.registers)
|
assert_equal({ "one" => 7, "two" => 8, "three" => 9 }, newest_register.registers)
|
||||||
assert_equal({ nil => true, 1 => :one, :one => "one", "two" => 3, false => nil }, static_register.static_registers)
|
assert_equal({ nil => true, 1 => :one, :one => "one", "two" => 3, false => nil }, static_register.static)
|
||||||
assert_equal({ foo: :bar }, new_register.static_registers)
|
assert_equal({ foo: :bar }, new_register.static)
|
||||||
assert_equal({ bar: :foo }, newest_register.static_registers)
|
assert_equal({ bar: :foo }, newest_register.static)
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_can_update_static_directly_and_updates_all_instances
|
||||||
|
static_register = StaticRegisters.new(nil => true, 1 => :one, :one => "one", "two" => 3, false => nil)
|
||||||
|
static_register["one"] = 1
|
||||||
|
static_register["two"] = 2
|
||||||
|
static_register["three"] = 3
|
||||||
|
|
||||||
|
new_register = StaticRegisters.new(static_register)
|
||||||
|
assert_equal({}, new_register.registers)
|
||||||
|
|
||||||
|
assert_equal({ nil => true, 1 => :one, :one => "one", "two" => 3, false => nil }, static_register.static)
|
||||||
|
|
||||||
|
new_register["one"] = 4
|
||||||
|
new_register["two"] = 5
|
||||||
|
new_register["three"] = 6
|
||||||
|
new_register.static["four"] = 10
|
||||||
|
|
||||||
|
newest_register = StaticRegisters.new(new_register)
|
||||||
|
assert_equal({}, newest_register.registers)
|
||||||
|
|
||||||
|
assert_equal({ nil => true, 1 => :one, :one => "one", "two" => 3, false => nil, "four" => 10 }, new_register.static)
|
||||||
|
|
||||||
|
newest_register["one"] = 7
|
||||||
|
newest_register["two"] = 8
|
||||||
|
newest_register["three"] = 9
|
||||||
|
new_register.static["four"] = 5
|
||||||
|
new_register.static["five"] = 15
|
||||||
|
|
||||||
|
assert_equal({ "one" => 1, "two" => 2, "three" => 3 }, static_register.registers)
|
||||||
|
assert_equal({ "one" => 4, "two" => 5, "three" => 6 }, new_register.registers)
|
||||||
|
assert_equal({ "one" => 7, "two" => 8, "three" => 9 }, newest_register.registers)
|
||||||
|
|
||||||
|
assert_equal({ nil => true, 1 => :one, :one => "one", "two" => 3, false => nil, "four" => 5, "five" => 15 }, newest_register.static)
|
||||||
|
|
||||||
|
assert_equal({ nil => true, 1 => :one, :one => "one", "two" => 3, false => nil, "four" => 5, "five" => 15 }, static_register.static)
|
||||||
|
assert_equal({ nil => true, 1 => :one, :one => "one", "two" => 3, false => nil, "four" => 5, "five" => 15 }, new_register.static)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
Reference in New Issue
Block a user