3
# Unix SMB/CIFS implementation.
4
# Copyright (C) Jelmer Vernooij <jelmer@samba.org> 2008
6
# This program is free software; you can redistribute it and/or modify
7
# it under the terms of the GNU General Public License as published by
8
# the Free Software Foundation; either version 3 of the License, or
9
# (at your option) any later version.
11
# This program is distributed in the hope that it will be useful,
12
# but WITHOUT ANY WARRANTY; without even the implied warranty of
13
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14
# GNU General Public License for more details.
16
# You should have received a copy of the GNU General Public License
17
# along with this program. If not, see <http://www.gnu.org/licenses/>.
20
from samba.dcerpc import echo
21
from samba.ndr import ndr_pack, ndr_unpack
23
from samba.tests import RpcInterfaceTestCase
26
class RpcEchoTests(RpcInterfaceTestCase):
28
self.conn = echo.rpcecho("ncalrpc:", self.get_loadparm())
30
def test_two_contexts(self):
31
self.conn2 = echo.rpcecho("ncalrpc:", self.get_loadparm(), basis_connection=self.conn)
32
self.assertEquals(3, self.conn2.AddOne(2))
34
def test_abstract_syntax(self):
35
self.assertEquals(("60a15ec5-4de8-11d7-a637-005056a20182", 1),
36
self.conn.abstract_syntax)
38
def test_addone(self):
39
self.assertEquals(2, self.conn.AddOne(1))
41
def test_echodata(self):
42
self.assertEquals([1,2,3], self.conn.EchoData([1, 2, 3]))
45
self.assertEquals(u"foobar", self.conn.TestCall(u"foobar"))
47
def test_surrounding(self):
48
surrounding_struct = echo.Surrounding()
49
surrounding_struct.x = 4
50
surrounding_struct.surrounding = [1,2,3,4]
51
y = self.conn.TestSurrounding(surrounding_struct)
52
self.assertEquals(4 * [0], y.surrounding)
54
def test_manual_request(self):
55
self.assertEquals("\x01\x00\x00\x00", self.conn.request(0, chr(0) * 4))
57
def test_server_name(self):
58
self.assertEquals(None, self.conn.server_name)
61
class NdrEchoTests(unittest.TestCase):
62
def test_info1_push(self):
65
self.assertEquals("\x2a", ndr_pack(x))
67
def test_info1_pull(self):
68
x = ndr_unpack(echo.info1, "\x42")
69
self.assertEquals(x.v, 66)