Improve DB::MappingException usage (#129)

This commit is contained in:
Johannes Müller 2021-10-13 01:51:53 +02:00 committed by GitHub
parent b1299fcada
commit 5a7d27e0c5
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 33 additions and 16 deletions

View file

@ -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

View file

@ -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

View file

@ -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 %}

View file

@ -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