v/vlib/orm/orm_test.v

182 lines
4.0 KiB
V
Raw Normal View History

2020-06-17 00:59:33 +02:00
//import os
//import pg
//import term
2020-06-16 12:14:22 +02:00
import sqlite
2020-06-07 15:44:33 +02:00
2020-06-17 04:05:13 +02:00
struct Module {
2020-06-07 15:44:33 +02:00
id int
user_id int
2020-06-17 04:05:13 +02:00
//name string
//url string
2020-06-07 15:44:33 +02:00
//nr_downloads int
2019-08-02 06:57:35 +02:00
}
2020-06-17 00:59:33 +02:00
struct User {
id int
2020-06-17 04:05:13 +02:00
age int
2020-06-17 00:59:33 +02:00
name string
2020-06-23 13:59:00 +02:00
is_customer bool
2020-06-17 00:59:33 +02:00
}
2020-06-16 12:14:22 +02:00
fn test_orm_sqlite() {
db := sqlite.connect(':memory:') or { panic(err) }
2020-06-17 00:59:33 +02:00
db.exec("drop table if exists User")
2020-06-23 13:59:00 +02:00
db.exec("create table User (id integer primary key, age int default 0, name text default '', is_customer int default 0);")
2020-06-17 00:59:33 +02:00
name := 'Peter'
2020-06-17 00:59:33 +02:00
2020-06-17 04:05:13 +02:00
db.exec("insert into User (name, age) values ('Sam', 29)")
2020-06-17 14:18:32 +02:00
db.exec("insert into User (name, age) values ('Peter', 31)")
2020-06-23 13:59:00 +02:00
db.exec("insert into User (name, age, is_customer) values ('Kate', 30, 1)")
2020-06-17 00:59:33 +02:00
nr_all_users := sql db {
select count from User
2020-06-16 12:14:22 +02:00
}
2020-06-17 00:59:33 +02:00
assert nr_all_users == 3
println('nr_all_users=$nr_all_users')
//
nr_users1 := sql db {
select count from User where id == 1
}
assert nr_users1 == 1
println('nr_users1=$nr_users1')
//
nr_peters := sql db {
select count from User where id == 2 && name == 'Peter'
}
assert nr_peters == 1
println('nr_peters=$nr_peters')
//
nr_peters2 := sql db {
select count from User where id == 2 && name == name
2020-06-17 00:59:33 +02:00
}
assert nr_peters2 == 1
nr_peters3 := sql db {
select count from User where name == name
}
assert nr_peters3 == 1
peters := sql db {
2020-06-22 16:58:43 +02:00
select from User where name == name
}
assert peters.len == 1
assert peters[0].name == 'Peter'
2020-06-22 16:58:43 +02:00
one_peter := sql db {
select from User where name == name limit 1
}
assert one_peter.name == 'Peter'
assert one_peter.id == 2
2020-06-17 04:05:13 +02:00
//
user := sql db {
select from User where id == 1
}
println(user)
assert user.name == 'Sam'
assert user.id == 1
assert user.age == 29
2020-06-17 14:18:32 +02:00
//
users := sql db {
select from User where id > 0
}
println(users)
assert users.len == 3
assert users[0].name == 'Sam'
assert users[1].name == 'Peter'
assert users[1].age == 31
2020-06-17 14:29:44 +02:00
//
users2 := sql db {
select from User where id < 0
}
println(users2)
assert users2.len == 0
//
users3 := sql db {
select from User where age == 29 || age == 31
}
println(users3)
assert users3.len == 2
assert users3[0].age == 29
assert users3[1].age == 31
2020-06-19 16:43:32 +02:00
//
2020-06-17 20:18:48 +02:00
2020-06-19 16:43:32 +02:00
new_user := User{name:'New user' age:30}
sql db {
insert new_user into User
}
2020-06-17 20:18:48 +02:00
//db.insert<User>(user2)
2020-06-19 16:43:32 +02:00
x := sql db {
select from User where id == 4
}
println(x)
assert x.age == 30
assert x.id == 4
assert x.name == 'New user'
2020-06-23 13:59:00 +02:00
//
kate := sql db {
select from User where id == 3
}
println(kate)
assert kate.is_customer == true
//
customer := sql db {
select from User where is_customer == true limit 1
}
println(customer)
assert customer.is_customer == true
assert customer.name == 'Kate'
2020-06-16 12:14:22 +02:00
}
fn test_orm_pg() {
2020-06-17 00:59:33 +02:00
/*
dbname := os.getenv('VDB_NAME')
dbuser := os.getenv('VDB_USER')
if dbname == '' || dbuser == '' {
eprintln(term.red('NB: this test requires VDB_NAME and VDB_USER env variables to be set'))
return
}
db := pg.connect(dbname: dbname, user: dbuser) or { panic(err) }
2020-06-16 12:14:22 +02:00
_ = db
2020-06-17 00:59:33 +02:00
nr_modules := db.select count from modules
2020-06-07 15:44:33 +02:00
//nr_modules := db.select count from Modules where id == 1
nr_modules := db.select count from Modules where
name == 'Bob' && id == 1
println(nr_modules)
mod := db.select from Modules where id = 1 limit 1
println(mod)
mods := db.select from Modules limit 10
for mod in mods {
println(mod)
}
*/
/*
mod := db.retrieve<Module>(1)
2020-06-17 00:59:33 +02:00
mod := db.select from Module where id = 1
2020-06-07 15:44:33 +02:00
mod := db.update Module set name = name + '!' where id > 10
nr_modules := db.select count from Modules
where id > 1 && name == ''
println(nr_modules)
nr_modules := db.select count from modules
nr_modules := db.select from modules
nr_modules := db[:modules].select
*/
/*
mod := select from db.modules where id = 1 limit 1
println(mod.name)
top_mods := select from db.modules where nr_downloads > 1000 order by nr_downloads desc limit 10
top_mods := db.select from modules where nr_downloads > 1000 order by nr_downloads desc limit 10
top_mods := db.select<Module>(m => m.nr_downloads > 1000).order_by(m => m.nr_downloads).desc().limit(10)
names := select name from db.modules // []string
n := db.q_int('select count(*) from modules')
println(n)
*/
}