~jan-kneschke/mysql-proxy/packet-tracking-assertions

« back to all changes in this revision

Viewing changes to tests/suite/base/t/ignore-resultset-mock.lua

  • Committer: Kay Roepke
  • Author(s): Jan Kneschke
  • Date: 2008-01-23 22:00:28 UTC
  • Revision ID: kay@mysql.com-20080123220028-hq2xqb69apa75fnx
first round on mysql-shell based on the proxy code

this is mostly a verification if the proxy-code is flexible enough to handle 
all three scenarios of: client, server and forwarding (proxy)

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
--[[ $%BEGINLICENSE%$
2
 
 Copyright (c) 2008, Oracle and/or its affiliates. All rights reserved.
3
 
 
4
 
 This program is free software; you can redistribute it and/or
5
 
 modify it under the terms of the GNU General Public License as
6
 
 published by the Free Software Foundation; version 2 of the
7
 
 License.
8
 
 
9
 
 This program is distributed in the hope that it will be useful,
10
 
 but WITHOUT ANY WARRANTY; without even the implied warranty of
11
 
 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12
 
 GNU General Public License for more details.
13
 
 
14
 
 You should have received a copy of the GNU General Public License
15
 
 along with this program; if not, write to the Free Software
16
 
 Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
17
 
 02110-1301  USA
18
 
 
19
 
 $%ENDLICENSE%$ --]]
20
 
local proto = require("mysql.proto")
21
 
 
22
 
function connect_server()
23
 
        -- emulate a server
24
 
        proxy.response = {
25
 
                type = proxy.MYSQLD_PACKET_RAW,
26
 
                packets = {
27
 
                        proto.to_challenge_packet({})
28
 
                }
29
 
        }
30
 
        return proxy.PROXY_SEND_RESULT
31
 
end
32
 
 
33
 
function read_query(packet)
34
 
        if packet:byte() ~= proxy.COM_QUERY then
35
 
                proxy.response = {
36
 
                        type = proxy.MYSQLD_PACKET_OK
37
 
                }
38
 
                return proxy.PROXY_SEND_RESULT
39
 
        end
40
 
 
41
 
        local query = packet:sub(2) 
42
 
        if query == 'SELECT 1' then
43
 
                proxy.response = {
44
 
                        type = proxy.MYSQLD_PACKET_OK,
45
 
                        resultset = {
46
 
                                fields = {
47
 
                                        { name = '1' },
48
 
                                },
49
 
                                rows = { { 1 } }
50
 
                        }
51
 
                }
52
 
        else
53
 
                proxy.response = {
54
 
                        type = proxy.MYSQLD_PACKET_ERR,
55
 
                        errmsg = "(resultset-mock) >" .. query .. "<"
56
 
                }
57
 
        end
58
 
        return proxy.PROXY_SEND_RESULT
59
 
end
60
 
 
61
 
 
62
 
 
63