mirror of
https://gitea.invidious.io/iv-org/shard-crystal-db.git
synced 2024-08-15 00:53:32 +00:00
Improve DB::MappingException usage (#129)
This commit is contained in:
parent
b1299fcada
commit
5a7d27e0c5
4 changed files with 33 additions and 16 deletions
|
@ -105,19 +105,19 @@ describe "DB::Serializable" do
|
||||||
end
|
end
|
||||||
|
|
||||||
it "should fail to initialize a simple model if types do not match" do
|
it "should fail to initialize a simple model if types do not match" do
|
||||||
expect_raises ArgumentError do
|
expect_raises DB::MappingException, "Invalid Int32: b\n deserializing SimpleModel#c0" do
|
||||||
from_dummy("b,a", SimpleModel)
|
from_dummy("b,a", SimpleModel)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
it "should fail to initialize a simple model if there is a missing column" do
|
it "should fail to initialize a simple model if there is a missing column" do
|
||||||
expect_raises DB::MappingException do
|
expect_raises DB::MappingException, "Missing column c1\n deserializing SimpleModel#c1" do
|
||||||
from_dummy("1", SimpleModel)
|
from_dummy("1", SimpleModel)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
it "should fail to initialize a simple model if there is an unexpected column" do
|
it "should fail to initialize a simple model if there is an unexpected column" do
|
||||||
expect_raises DB::MappingException do
|
expect_raises DB::MappingException, "Unknown column: c2\n deserializing SimpleModel" do
|
||||||
from_dummy("1,a,b", SimpleModel)
|
from_dummy("1,a,b", SimpleModel)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -6,6 +6,19 @@ module DB
|
||||||
end
|
end
|
||||||
|
|
||||||
class MappingException < Error
|
class MappingException < Error
|
||||||
|
getter klass
|
||||||
|
getter property
|
||||||
|
|
||||||
|
def initialize(message, @klass : String, @property : String? = nil, cause : Exception? = nil)
|
||||||
|
message = String.build do |io|
|
||||||
|
io << message
|
||||||
|
io << "\n deserializing " << @klass
|
||||||
|
if property = @property
|
||||||
|
io << "#" << property
|
||||||
|
end
|
||||||
|
end
|
||||||
|
super(message, cause: cause)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
class PoolTimeout < Error
|
class PoolTimeout < Error
|
||||||
|
|
|
@ -117,7 +117,7 @@ module DB
|
||||||
{% end %}
|
{% end %}
|
||||||
else
|
else
|
||||||
{% if strict %}
|
{% if strict %}
|
||||||
raise ::DB::MappingException.new("unknown result set attribute: #{col_name}")
|
raise ::DB::MappingException.new("unknown result set attribute: #{col_name}", self.class.to_s)
|
||||||
{% else %}
|
{% else %}
|
||||||
%rs.read
|
%rs.read
|
||||||
{% end %}
|
{% end %}
|
||||||
|
@ -127,7 +127,7 @@ module DB
|
||||||
{% for key, value in properties %}
|
{% for key, value in properties %}
|
||||||
{% unless value[:nilable] || value[:default] != nil %}
|
{% unless value[:nilable] || value[:default] != nil %}
|
||||||
if %var{key.id}.is_a?(Nil) && !%found{key.id}
|
if %var{key.id}.is_a?(Nil) && !%found{key.id}
|
||||||
raise ::DB::MappingException.new("missing result set attribute: {{(value[:key] || key).id}}")
|
raise ::DB::MappingException.new("missing result set attribute: {{(value[:key] || key).id}}", self.class.to_s)
|
||||||
end
|
end
|
||||||
{% end %}
|
{% end %}
|
||||||
{% end %}
|
{% end %}
|
||||||
|
|
|
@ -129,14 +129,18 @@ module DB
|
||||||
{% for name, value in properties %}
|
{% for name, value in properties %}
|
||||||
when {{value[:key]}}
|
when {{value[:key]}}
|
||||||
%found{name} = true
|
%found{name} = true
|
||||||
%var{name} =
|
begin
|
||||||
{% if value[:converter] %}
|
%var{name} =
|
||||||
{{value[:converter]}}.from_rs(rs)
|
{% if value[:converter] %}
|
||||||
{% elsif value[:nilable] || value[:default] != nil %}
|
{{value[:converter]}}.from_rs(rs)
|
||||||
rs.read(::Union({{value[:type]}} | Nil))
|
{% elsif value[:nilable] || value[:default] != nil %}
|
||||||
{% else %}
|
rs.read(::Union({{value[:type]}} | Nil))
|
||||||
rs.read({{value[:type]}})
|
{% else %}
|
||||||
{% end %}
|
rs.read({{value[:type]}})
|
||||||
|
{% end %}
|
||||||
|
rescue exc
|
||||||
|
::raise ::DB::MappingException.new(exc.message, self.class.to_s, {{name.stringify}}, cause: exc)
|
||||||
|
end
|
||||||
{% end %}
|
{% end %}
|
||||||
else
|
else
|
||||||
rs.read # Advance set, but discard result
|
rs.read # Advance set, but discard result
|
||||||
|
@ -146,8 +150,8 @@ module DB
|
||||||
|
|
||||||
{% for key, value in properties %}
|
{% for key, value in properties %}
|
||||||
{% unless value[:nilable] || value[:default] != nil %}
|
{% unless value[:nilable] || value[:default] != nil %}
|
||||||
if %var{key}.is_a?(Nil) && !%found{key}
|
if %var{key}.nil? && !%found{key}
|
||||||
raise ::DB::MappingException.new("missing result set attribute: {{(value[:key] || key).id}}")
|
::raise ::DB::MappingException.new("Missing column {{value[:key].id}}", self.class.to_s, {{key.stringify}})
|
||||||
end
|
end
|
||||||
{% end %}
|
{% end %}
|
||||||
{% end %}
|
{% end %}
|
||||||
|
@ -169,7 +173,7 @@ module DB
|
||||||
end
|
end
|
||||||
|
|
||||||
protected def on_unknown_db_column(col_name)
|
protected def on_unknown_db_column(col_name)
|
||||||
raise ::DB::MappingException.new("unknown result set attribute: #{col_name}")
|
::raise ::DB::MappingException.new("Unknown column: #{col_name}", self.class.to_s)
|
||||||
end
|
end
|
||||||
|
|
||||||
module NonStrict
|
module NonStrict
|
||||||
|
|
Loading…
Reference in a new issue