mirror of
https://gitea.invidious.io/iv-org/shard-crystal-db.git
synced 2024-08-15 00:53:32 +00:00
docs & formatting
This commit is contained in:
parent
456ff5aa36
commit
6c7aea0528
1 changed files with 55 additions and 3 deletions
58
src/spec.cr
58
src/spec.cr
|
@ -7,8 +7,48 @@ private def assert_single_read(rs, value_type, value)
|
||||||
end
|
end
|
||||||
|
|
||||||
module DB
|
module DB
|
||||||
|
# Helper class to ensure behaviour of custom drivers
|
||||||
|
#
|
||||||
|
# ```
|
||||||
|
# require "db/spec"
|
||||||
|
#
|
||||||
|
# DB::DriverSpecs(DB::Any).run do
|
||||||
|
# # How to connect to database
|
||||||
|
# connection_string "scheme://database_url"
|
||||||
|
#
|
||||||
|
# # Clean up database if needed using before/after callbacks
|
||||||
|
# before do
|
||||||
|
# # ...
|
||||||
|
# end
|
||||||
|
#
|
||||||
|
# after do
|
||||||
|
# # ...
|
||||||
|
# end
|
||||||
|
#
|
||||||
|
# # Sample values that will be stored, retrieved across many specs
|
||||||
|
# sample_value "hello", "varchar(25)", "'hello'"
|
||||||
|
#
|
||||||
|
# it "custom spec with a db initialized" do |db|
|
||||||
|
# # assert something using *db*
|
||||||
|
# end
|
||||||
|
#
|
||||||
|
# # Configure the appropiate syntax for different commands needed to run the specs
|
||||||
|
# binding_syntax do |index|
|
||||||
|
# "?"
|
||||||
|
# end
|
||||||
|
#
|
||||||
|
# create_table_1column_syntax do |table_name, col1|
|
||||||
|
# "create table #{table_name} (#{col1.name} #{col1.sql_type} #{col1.null ? "NULL" : "NOT NULL"})"
|
||||||
|
# end
|
||||||
|
# end
|
||||||
|
# ```
|
||||||
|
#
|
||||||
|
# The following methods needs to be called to configure the appropiate syntax
|
||||||
|
# for different commands and allow all the specs to run: `binding_syntax`, `create_table_1column_syntax`,
|
||||||
|
# `create_table_2columns_syntax`, `select_1column_syntax`, `select_2columns_syntax`, `select_count_syntax`,
|
||||||
|
# `select_scalar_syntax`, `insert_1column_syntax`, `insert_2columns_syntax`, `drop_table_if_exists_syntax`.
|
||||||
|
#
|
||||||
class DriverSpecs(DBAnyType)
|
class DriverSpecs(DBAnyType)
|
||||||
|
|
||||||
record ColumnDef, name : String, sql_type : String, null : Bool
|
record ColumnDef, name : String, sql_type : String, null : Bool
|
||||||
|
|
||||||
@before : Proc(Nil) = ->{}
|
@before : Proc(Nil) = ->{}
|
||||||
|
@ -26,16 +66,20 @@ module DB
|
||||||
def encode_null(@encode_null : String)
|
def encode_null(@encode_null : String)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Allow specs that uses prepared statements (default `true`)
|
||||||
def support_prepared(@support_prepared : Bool)
|
def support_prepared(@support_prepared : Bool)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# :nodoc:
|
||||||
def support_prepared
|
def support_prepared
|
||||||
@support_prepared
|
@support_prepared
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Allow specs that uses unprepared statements (default `true`)
|
||||||
def support_unprepared(@support_unprepared : Bool)
|
def support_unprepared(@support_unprepared : Bool)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# :nodoc:
|
||||||
def support_unprepared
|
def support_unprepared
|
||||||
@support_unprepared
|
@support_unprepared
|
||||||
end
|
end
|
||||||
|
@ -56,7 +100,7 @@ module DB
|
||||||
# :nodoc:
|
# :nodoc:
|
||||||
def {{name.var.id}}
|
def {{name.var.id}}
|
||||||
res = @{{name.var.id}}
|
res = @{{name.var.id}}
|
||||||
raise %{Missing {{name.var.id}} to setup db} unless res
|
raise "Missing {{name.var.id}} to setup db" unless res
|
||||||
res
|
res
|
||||||
end
|
end
|
||||||
{% end %}
|
{% end %}
|
||||||
|
@ -74,6 +118,7 @@ module DB
|
||||||
db_spec_config select_count_syntax : Proc(String, String), block: true
|
db_spec_config select_count_syntax : Proc(String, String), block: true
|
||||||
db_spec_config drop_table_if_exists_syntax : Proc(String, String), block: true
|
db_spec_config drop_table_if_exists_syntax : Proc(String, String), block: true
|
||||||
|
|
||||||
|
# :nodoc:
|
||||||
record SpecIt, description : String, prepared : Symbol, file : String, line : Int32, end_line : Int32, block : DB::Database -> Nil
|
record SpecIt, description : String, prepared : Symbol, file : String, line : Int32, end_line : Int32, block : DB::Database -> Nil
|
||||||
getter its = [] of SpecIt
|
getter its = [] of SpecIt
|
||||||
|
|
||||||
|
@ -82,9 +127,15 @@ module DB
|
||||||
@its << SpecIt.new(description, prepared, file, line, end_line, block)
|
@its << SpecIt.new(description, prepared, file, line, end_line, block)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# :nodoc:
|
||||||
record ValueDef(T), value : T, sql_type : String, value_encoded : String
|
record ValueDef(T), value : T, sql_type : String, value_encoded : String
|
||||||
|
|
||||||
@values = [] of ValueDef(DBAnyType)
|
@values = [] of ValueDef(DBAnyType)
|
||||||
|
|
||||||
|
# Use *value* as sample value that should be stored in columns of type *sql_type*.
|
||||||
|
# *value_encoded* is driver specific expression that should generate that value in the database.
|
||||||
|
# *type_safe_value* indicates whether *value_encoded* is expected to generate the *value* even without
|
||||||
|
# been stored in a table (default `true`).
|
||||||
def sample_value(value, sql_type, value_encoded, *, type_safe_value = true)
|
def sample_value(value, sql_type, value_encoded, *, type_safe_value = true)
|
||||||
@values << ValueDef(DBAnyType).new(value, sql_type, value_encoded)
|
@values << ValueDef(DBAnyType).new(value, sql_type, value_encoded)
|
||||||
|
|
||||||
|
@ -340,10 +391,12 @@ module DB
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# :nodoc:
|
||||||
def col_name
|
def col_name
|
||||||
ColumnDef.new("name", sql_type_for(String), false)
|
ColumnDef.new("name", sql_type_for(String), false)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# :nodoc:
|
||||||
def col_age
|
def col_age
|
||||||
ColumnDef.new("age", sql_type_for(Int32), false)
|
ColumnDef.new("age", sql_type_for(Int32), false)
|
||||||
end
|
end
|
||||||
|
@ -455,7 +508,6 @@ module DB
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue