mirror of
https://github.com/vlang/v.git
synced 2025-08-03 17:57:59 -04:00
90 lines
2.4 KiB
V
90 lines
2.4 KiB
V
import db.mysql
|
|
|
|
fn test_mysql() {
|
|
$if !network ? {
|
|
eprintln('> Skipping test ${@FN}, since `-d network` is not passed.')
|
|
eprintln('> This test requires a working mysql server running on localhost.')
|
|
return
|
|
}
|
|
config := mysql.Config{
|
|
host: '127.0.0.1'
|
|
port: 3306
|
|
username: 'root'
|
|
password: ''
|
|
dbname: 'mysql'
|
|
}
|
|
|
|
db := mysql.connect(config)!
|
|
|
|
mut response := db.exec('drop table if exists users')!
|
|
assert response == []mysql.Row{}
|
|
|
|
response = db.exec('create table if not exists users (
|
|
id INT PRIMARY KEY AUTO_INCREMENT,
|
|
username TEXT,
|
|
last_name TEXT NULL DEFAULT NULL
|
|
)')!
|
|
assert response == []mysql.Row{}
|
|
|
|
mut result_code := db.exec_none('insert into users (username) values ("jackson")')
|
|
assert result_code == 0
|
|
result_code = db.exec_none('insert into users (username) values ("shannon")')
|
|
assert result_code == 0
|
|
result_code = db.exec_none('insert into users (username) values ("bailey")')
|
|
assert result_code == 0
|
|
result_code = db.exec_none('insert into users (username) values ("blaze")')
|
|
assert result_code == 0
|
|
rows := db.exec_param('insert into users (username) values (?)', 'Hi')!
|
|
assert rows == []mysql.Row{}
|
|
|
|
// Regression testing to ensure the query and exec return the same values
|
|
res := db.query('select * from users')!
|
|
response = res.rows()
|
|
assert response[0].vals[1] == 'jackson'
|
|
response = db.exec('select * from users')!
|
|
assert response[0].vals[1] == 'jackson'
|
|
|
|
response = db.exec('select * from users where id = 400')!
|
|
assert response.len == 0
|
|
|
|
single_row := db.exec_one('select * from users')!
|
|
assert single_row.vals[1] == 'jackson'
|
|
|
|
response = db.exec_param_many('select * from users where username = ?', [
|
|
'jackson',
|
|
])!
|
|
assert response[0] == mysql.Row{
|
|
vals: ['1', 'jackson', '']
|
|
}
|
|
|
|
response = db.exec_param_many('select * from users where username = ? and id = ?',
|
|
['bailey', '3'])!
|
|
assert response[0] == mysql.Row{
|
|
vals: ['3', 'bailey', '']
|
|
}
|
|
|
|
response = db.exec_param_many('select * from users', [''])!
|
|
assert response == [
|
|
mysql.Row{
|
|
vals: ['1', 'jackson', '']
|
|
},
|
|
mysql.Row{
|
|
vals: ['2', 'shannon', '']
|
|
},
|
|
mysql.Row{
|
|
vals: ['3', 'bailey', '']
|
|
},
|
|
mysql.Row{
|
|
vals: ['4', 'blaze', '']
|
|
},
|
|
mysql.Row{
|
|
vals: ['5', 'Hi', '']
|
|
},
|
|
]
|
|
|
|
response = db.exec_param('select * from users where username = ?', 'blaze')!
|
|
assert response[0] == mysql.Row{
|
|
vals: ['4', 'blaze', '']
|
|
}
|
|
}
|