Code

client: Add helper functions for formatting and executing queries.
[sysdb/go.git] / client / query_test.go
1 //
2 // Copyright (C) 2015 Sebastian 'tokkee' Harl <sh@tokkee.org>
3 // All rights reserved.
4 //
5 // Redistribution and use in source and binary forms, with or without
6 // modification, are permitted provided that the following conditions
7 // are met:
8 // 1. Redistributions of source code must retain the above copyright
9 //    notice, this list of conditions and the following disclaimer.
10 // 2. Redistributions in binary form must reproduce the above copyright
11 //    notice, this list of conditions and the following disclaimer in the
12 //    documentation and/or other materials provided with the distribution.
13 //
14 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
15 // ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
16 // TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
17 // PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR
18 // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
19 // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
20 // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
21 // OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
22 // WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
23 // OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
24 // ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26 package client
28 import (
29         "testing"
30         "time"
31 )
33 func TestQueryString(t *testing.T) {
34         ts, _ := time.Parse("2006-01-02 15:04:05", "2006-01-02 15:04:05")
35         for _, test := range []struct {
36                 q       string
37                 args    []interface{}
38                 want    string
39                 wantErr bool
40         }{
41                 {"some %s; foo %s", []interface{}{"thing", "bar"}, "some 'thing'; foo 'bar'", false},
42                 {"s=%s", []interface{}{"'a"}, "s='''a'", false},
43                 {"t=%s", []interface{}{ts}, "t=2006-01-02 15:04:05", false},
44                 {"i=%s; f=%s", []interface{}{1234, 47.11}, "i=1234; f=4.711000e+01", false},
45                 {"t=%d", []interface{}{ts}, "", true},
46                 {"some %s; foo %s", []interface{}{"a", "b", "c"}, "", true},
47                 {"some %s; foo %s", []interface{}{"a"}, "", true},
48                 {"s=%s", []interface{}{`multi
49 line
50 text`}, "s='multi\nline\ntext'", false},
51                 {"s=%d", []interface{}{`multi
52 line
53 error`}, "", true},
54         } {
55                 s, err := QueryString(test.q, test.args...)
56                 if s != test.want || (err != nil) != test.wantErr {
57                         e := "<nil>"
58                         if test.wantErr {
59                                 e = "<err>"
60                         }
61                         t.Errorf("QueryString(%q, %v) = %q, %v; want %q, %s", test.q, test.args, s, err, test.want, e)
62                 }
63         }
64 }
66 // vim: set tw=78 sw=4 sw=4 noexpandtab :