|  | // Copyright (C) 2014 Yasuhiro Matsumoto <mattn.jp@gmail.com>. | 
|  | // | 
|  | // Use of this source code is governed by an MIT-style | 
|  | // license that can be found in the LICENSE file. | 
|  |  | 
|  | // +build go1.8 | 
|  |  | 
|  | package sqlite3 | 
|  |  | 
|  | import ( | 
|  | "database/sql" | 
|  | "os" | 
|  | "testing" | 
|  | ) | 
|  |  | 
|  | func TestNamedParams(t *testing.T) { | 
|  | tempFilename := TempFilename(t) | 
|  | defer os.Remove(tempFilename) | 
|  | db, err := sql.Open("sqlite3", tempFilename) | 
|  | if err != nil { | 
|  | t.Fatal("Failed to open database:", err) | 
|  | } | 
|  | defer db.Close() | 
|  |  | 
|  | _, err = db.Exec(` | 
|  | create table foo (id integer, name text, extra text); | 
|  | `) | 
|  | if err != nil { | 
|  | t.Error("Failed to call db.Query:", err) | 
|  | } | 
|  |  | 
|  | _, err = db.Exec(`insert into foo(id, name, extra) values(:id, :name, :name)`, sql.Param(":name", "foo"), sql.Param(":id", 1)) | 
|  | if err != nil { | 
|  | t.Error("Failed to call db.Exec:", err) | 
|  | } | 
|  |  | 
|  | row := db.QueryRow(`select id, extra from foo where id = :id and extra = :extra`, sql.Param(":id", 1), sql.Param(":extra", "foo")) | 
|  | if row == nil { | 
|  | t.Error("Failed to call db.QueryRow") | 
|  | } | 
|  | var id int | 
|  | var extra string | 
|  | err = row.Scan(&id, &extra) | 
|  | if err != nil { | 
|  | t.Error("Failed to db.Scan:", err) | 
|  | } | 
|  | if id != 1 || extra != "foo" { | 
|  | t.Error("Failed to db.QueryRow: not matched results") | 
|  | } | 
|  | } |