2015-05-28 19:19:08 -04:00
|
|
|
extern crate sqlite;
|
|
|
|
extern crate temporary;
|
|
|
|
|
|
|
|
macro_rules! ok(
|
|
|
|
($result:expr) => ($result.unwrap());
|
|
|
|
);
|
|
|
|
|
|
|
|
#[test]
|
2015-05-29 11:24:01 -04:00
|
|
|
fn workflow() {
|
2015-06-08 17:43:31 -04:00
|
|
|
use sqlite::State;
|
2015-05-29 11:24:01 -04:00
|
|
|
|
2015-05-28 22:49:00 -04:00
|
|
|
macro_rules! pair(
|
2015-06-08 21:42:34 -04:00
|
|
|
($one:expr, $two:expr) => (($one, Some($two)));
|
2015-05-28 22:49:00 -04:00
|
|
|
);
|
|
|
|
|
2015-07-04 08:53:26 -04:00
|
|
|
let connection = ok!(sqlite::open(":memory:"));
|
2015-05-28 21:30:02 -04:00
|
|
|
|
|
|
|
let sql = r#"CREATE TABLE `users` (id INTEGER, name VARCHAR(255), age REAL);"#;
|
2015-07-04 08:53:26 -04:00
|
|
|
ok!(connection.execute(sql));
|
2015-05-28 21:30:02 -04:00
|
|
|
|
2015-05-29 13:08:02 -04:00
|
|
|
{
|
|
|
|
let sql = r#"INSERT INTO `users` (id, name, age) VALUES (?, ?, ?);"#;
|
2015-07-04 08:53:26 -04:00
|
|
|
let mut statement = ok!(connection.prepare(sql));
|
2015-06-19 13:03:47 -04:00
|
|
|
ok!(statement.bind(1, 1i64));
|
2015-06-19 11:31:29 -04:00
|
|
|
ok!(statement.bind(2, "Alice"));
|
|
|
|
ok!(statement.bind(3, 20.99));
|
2015-06-08 17:43:31 -04:00
|
|
|
assert!(ok!(statement.step()) == State::Done);
|
2015-05-29 13:08:02 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
{
|
|
|
|
let mut done = false;
|
|
|
|
let sql = r#"SELECT * FROM `users`;"#;
|
2015-07-04 08:53:26 -04:00
|
|
|
ok!(connection.process(sql, |pairs| {
|
2015-05-29 13:08:02 -04:00
|
|
|
assert!(pairs.len() == 3);
|
|
|
|
assert!(pairs[0] == pair!("id", "1"));
|
|
|
|
assert!(pairs[1] == pair!("name", "Alice"));
|
|
|
|
assert!(pairs[2] == pair!("age", "20.99"));
|
|
|
|
done = true;
|
|
|
|
true
|
2015-06-08 13:27:07 -04:00
|
|
|
}));
|
2015-05-29 13:08:02 -04:00
|
|
|
assert!(done);
|
|
|
|
}
|
|
|
|
|
|
|
|
{
|
|
|
|
let sql = r#"SELECT * FROM `users`;"#;
|
2015-07-04 08:53:26 -04:00
|
|
|
let mut statement = ok!(connection.prepare(sql));
|
2015-06-08 17:43:31 -04:00
|
|
|
assert!(ok!(statement.step()) == State::Row);
|
2015-06-19 11:31:29 -04:00
|
|
|
assert!(ok!(statement.read::<i64>(0)) == 1);
|
|
|
|
assert!(ok!(statement.read::<String>(1)) == String::from("Alice"));
|
|
|
|
assert!(ok!(statement.read::<f64>(2)) == 20.99);
|
2015-06-08 17:43:31 -04:00
|
|
|
assert!(ok!(statement.step()) == State::Done);
|
2015-05-29 13:08:02 -04:00
|
|
|
}
|
2015-05-28 19:19:08 -04:00
|
|
|
}
|
|
|
|
|
2015-06-11 22:14:36 -04:00
|
|
|
#[test]
|
|
|
|
fn stress() {
|
|
|
|
use sqlite::State;
|
2015-06-14 11:33:55 -04:00
|
|
|
use std::path::PathBuf;
|
|
|
|
use std::thread;
|
|
|
|
use temporary::Directory;
|
2015-06-11 22:14:36 -04:00
|
|
|
|
2015-06-14 11:33:55 -04:00
|
|
|
let directory = ok!(Directory::new("sqlite"));
|
|
|
|
let path = directory.path().join("database.sqlite3");
|
2015-06-11 22:14:36 -04:00
|
|
|
|
2015-07-04 08:53:26 -04:00
|
|
|
let connection = ok!(sqlite::open(&path));
|
2015-06-11 22:14:36 -04:00
|
|
|
let sql = r#"CREATE TABLE `users` (id INTEGER, name VARCHAR(255), age REAL);"#;
|
2015-07-04 08:53:26 -04:00
|
|
|
ok!(connection.execute(sql));
|
2015-06-11 22:14:36 -04:00
|
|
|
|
|
|
|
let guards = (0..100).map(|_| {
|
|
|
|
let path = PathBuf::from(&path);
|
|
|
|
thread::spawn(move || {
|
2015-07-04 08:53:26 -04:00
|
|
|
let mut connection = ok!(sqlite::open(&path));
|
|
|
|
ok!(connection.set_busy_handler(|_| true));
|
2015-06-11 22:14:36 -04:00
|
|
|
let sql = r#"INSERT INTO `users` (id, name, age) VALUES (?, ?, ?);"#;
|
2015-07-04 08:53:26 -04:00
|
|
|
let mut statement = ok!(connection.prepare(sql));
|
2015-06-19 13:03:47 -04:00
|
|
|
ok!(statement.bind(1, 1i64));
|
2015-06-19 11:31:29 -04:00
|
|
|
ok!(statement.bind(2, "Alice"));
|
|
|
|
ok!(statement.bind(3, 20.99));
|
2015-06-11 22:14:36 -04:00
|
|
|
assert!(ok!(statement.step()) == State::Done);
|
|
|
|
true
|
|
|
|
})
|
|
|
|
}).collect::<Vec<_>>();
|
|
|
|
|
|
|
|
for guard in guards {
|
|
|
|
assert!(guard.join().unwrap());
|
|
|
|
}
|
|
|
|
}
|