Skip to content

Commit 28d58cd

Browse files
author
Austin Ziegler
committed
Importing, but disabling, tests from other repos.
1 parent 090bad9 commit 28d58cd

File tree

3 files changed

+106
-35
lines changed

3 files changed

+106
-35
lines changed

test/test_ber.rb

Lines changed: 18 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -25,13 +25,20 @@ def test_encode_integer
2525
assert_equal( "\x02\x01\x01", 1.to_ber )
2626
assert_equal( "\x02\x01\x7F", 127.to_ber )
2727
assert_equal( "\x02\x01\x80", 128.to_ber )
28+
#assert_equal( "\x02\x02\x00\x80", 128.to_ber )
2829
assert_equal( "\x02\x01\xFF", 255.to_ber )
30+
#assert_equal( "\x02\x02\x00\xFF", 255.to_ber )
31+
2932

3033
assert_equal( "\x02\x02\x01\x00", 256.to_ber )
3134
assert_equal( "\x02\x02\xFF\xFF", 65535.to_ber )
35+
#assert_equal( "\x02\x03\x00\xFF\xFF", 65535.to_ber )
36+
3237

3338
assert_equal( "\x02\x03\x01\x00\x00", 65536.to_ber )
3439
assert_equal( "\x02\x03\xFF\xFF\xFF", 16_777_215.to_ber )
40+
#assert_equal( "\x02\x04\x00\xFF\xFF\xFF", 16_777_215.to_ber )
41+
3542

3643
assert_equal( "\x02\x04\x01\x00\x00\x00", 0x01000000.to_ber )
3744
assert_equal( "\x02\x04\x3F\xFF\xFF\xFF", 0x3FFFFFFF.to_ber )
@@ -48,6 +55,7 @@ def test_ber_integers
4855
assert_equal( "\002\001\005", 5.to_ber )
4956
assert_equal( "\002\002\001\364", 500.to_ber )
5057
assert_equal( "\x02\x02\xC3P", 50000.to_ber )
58+
#assert_equal( "\002\003\0\303P", 50000.to_ber )
5159
assert_equal( "\002\005\001*\005\362\000", 5000000000.to_ber )
5260
end
5361

@@ -68,11 +76,21 @@ def test_ber_parsing
6876
end
6977

7078
def test_ber_parser_on_ldap_bind_request
79+
require 'stringio'
80+
7181
s = StringIO.new(
7282
"0$\002\001\001`\037\002\001\003\004\rAdministrator\200\vad_is_bogus" )
7383

7484
assert_equal(
7585
[1, [3, "Administrator", "ad_is_bogus"]],
7686
s.read_ber( Net::LDAP::AsnSyntax ))
7787
end
88+
89+
def _test_oid
90+
oid = Net::BER::BerIdentifiedOid.new( [1,3,6,1,2,1,1,1,0] )
91+
assert_equal( "\006\b+\006\001\002\001\001\001\000", oid.to_ber )
92+
93+
oid = Net::BER::BerIdentifiedOid.new( "1.3.6.1.2.1.1.1.0" )
94+
assert_equal( "\006\b+\006\001\002\001\001\001\000", oid.to_ber )
95+
end
7896
end

test/test_entry.rb

Lines changed: 54 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,59 @@
11
require 'common'
22

3+
=begin
34
class TestEntry < Test::Unit::TestCase
4-
def test_entry
5-
# FIX
5+
Commented out until I can make it a spec.
6+
context "An instance of Entry" do
7+
setup do
8+
@entry = Net::LDAP::Entry.new 'cn=Barbara,o=corp'
9+
end
10+
11+
should "be initialized with the DN" do
12+
assert_equal 'cn=Barbara,o=corp', @entry.dn
13+
end
14+
15+
should 'return an empty array when accessing a nonexistent attribute (index lookup)' do
16+
assert_equal [], @entry['sn']
17+
end
18+
19+
should 'return an empty array when accessing a nonexistent attribute (method call)' do
20+
assert_equal [], @entry.sn
21+
end
22+
23+
should 'create an attribute on assignment (index lookup)' do
24+
@entry['sn'] = 'Jensen'
25+
assert_equal ['Jensen'], @entry['sn']
26+
end
27+
28+
should 'create an attribute on assignment (method call)' do
29+
@entry.sn = 'Jensen'
30+
assert_equal ['Jensen'], @entry.sn
31+
end
32+
33+
should 'have attributes accessible by index lookup' do
34+
@entry['sn'] = 'Jensen'
35+
assert_equal ['Jensen'], @entry['sn']
36+
end
37+
38+
should 'have attributes accessible using a Symbol as the index' do
39+
@entry[:sn] = 'Jensen'
40+
assert_equal ['Jensen'], @entry[:sn]
41+
end
42+
43+
should 'have attributes accessible by method call' do
44+
@entry['sn'] = 'Jensen'
45+
assert_equal ['Jensen'], @entry.sn
46+
end
47+
48+
should 'ignore case of attribute names' do
49+
@entry['sn'] = 'Jensen'
50+
assert_equal ['Jensen'], @entry.sn
51+
assert_equal ['Jensen'], @entry.Sn
52+
assert_equal ['Jensen'], @entry.SN
53+
assert_equal ['Jensen'], @entry['sn']
54+
assert_equal ['Jensen'], @entry['Sn']
55+
assert_equal ['Jensen'], @entry['SN']
56+
end
657
end
758
end
59+
=end

test/test_snmp.rb

Lines changed: 34 additions & 33 deletions
Original file line numberDiff line numberDiff line change
@@ -4,29 +4,38 @@
44
require 'net/snmp'
55

66
class TestSnmp < Test::Unit::TestCase
7-
87
SnmpGetRequest = "0'\002\001\000\004\006public\240\032\002\002?*\002\001\000\002\001\0000\0160\f\006\b+\006\001\002\001\001\001\000\005\000"
98
SnmpGetResponse = "0+\002\001\000\004\006public\242\036\002\002'\017\002\001\000\002\001\0000\0220\020\006\b+\006\001\002\001\001\001\000\004\004test"
109

1110
SnmpGetRequestXXX = "0'\002\001\000\004\006xxxxxx\240\032\002\002?*\002\001\000\002\001\0000\0160\f\006\b+\006\001\002\001\001\001\000\005\000"
1211

13-
14-
def setup
15-
end
16-
17-
def teardown
18-
end
19-
2012
def test_invalid_packet
2113
data = "xxxx"
22-
assert_raise( Net::BER::BerError ) {
14+
assert_raise(Net::BER::BerError) {
2315
ary = data.read_ber(Net::SNMP::AsnSyntax)
2416
}
17+
end
2518

19+
# The method String#read_ber! added by Net::BER consumes a well-formed BER
20+
# object from the head of a string. If it doesn't find a complete,
21+
# well-formed BER object, it returns nil and leaves the string unchanged.
22+
# If it finds an object, it returns the object and removes it from the
23+
# head of the string. This is good for handling partially-received data
24+
# streams, such as from network connections.
25+
def _test_consume_string
26+
data = "xxx"
27+
assert_equal(nil, data.read_ber!)
28+
assert_equal("xxx", data)
29+
30+
data = SnmpGetRequest + "!!!"
31+
ary = data.read_ber!(Net::SNMP::AsnSyntax)
32+
assert_equal("!!!", data)
33+
assert ary.is_a?(Array)
34+
assert ary.is_a?(Net::BER::BerIdentifiedArray)
2635
end
2736

2837
def test_weird_packet
29-
assert_raise( Net::SnmpPdu::Error ) {
38+
assert_raise(Net::SnmpPdu::Error) {
3039
Net::SnmpPdu.parse("aaaaaaaaaaaaaa")
3140
}
3241
end
@@ -35,39 +44,33 @@ def test_get_request
3544
data = SnmpGetRequest.dup
3645
pkt = data.read_ber(Net::SNMP::AsnSyntax)
3746
assert pkt.is_a?(Net::BER::BerIdentifiedArray)
38-
assert_equal( 48, pkt.ber_identifier) # Constructed [0], signifies GetRequest
47+
assert_equal(48, pkt.ber_identifier) # Constructed [0], signifies GetRequest
3948

4049
pdu = Net::SnmpPdu.parse(pkt)
41-
assert_equal(:get_request, pdu.pdu_type )
42-
assert_equal(16170, pdu.request_id ) # whatever was in the test data. 16170 is not magic.
43-
assert_equal( [[[1,3,6,1,2,1,1,1,0],nil]], pdu.variables )
50+
assert_equal(:get_request, pdu.pdu_type)
51+
assert_equal(16170, pdu.request_id) # whatever was in the test data. 16170 is not magic.
52+
assert_equal([[[1, 3, 6, 1, 2, 1, 1, 1, 0], nil]], pdu.variables)
4453

45-
assert_equal( pdu.to_ber_string, SnmpGetRequest )
54+
assert_equal(pdu.to_ber_string, SnmpGetRequest)
4655
end
4756

4857
def test_empty_pdu
4958
pdu = Net::SnmpPdu.new
50-
assert_raise( Net::SnmpPdu::Error ) {
51-
pdu.to_ber_string
52-
}
59+
assert_raise(Net::SnmpPdu::Error) { pdu.to_ber_string }
5360
end
5461

5562
def test_malformations
5663
pdu = Net::SnmpPdu.new
5764
pdu.version = 0
5865
pdu.version = 2
59-
assert_raise( Net::SnmpPdu::Error ) {
60-
pdu.version = 100
61-
}
66+
assert_raise(Net::SnmpPdu::Error) { pdu.version = 100 }
6267

6368
pdu.pdu_type = :get_request
6469
pdu.pdu_type = :get_next_request
6570
pdu.pdu_type = :get_response
6671
pdu.pdu_type = :set_request
6772
pdu.pdu_type = :trap
68-
assert_raise( Net::SnmpPdu::Error ) {
69-
pdu.pdu_type = :something_else
70-
}
73+
assert_raise(Net::SnmpPdu::Error) { pdu.pdu_type = :something_else }
7174
end
7275

7376
def test_make_response
@@ -78,9 +81,9 @@ def test_make_response
7881
pdu.request_id = 9999
7982
pdu.error_status = 0
8083
pdu.error_index = 0
81-
pdu.add_variable_binding [1,3,6,1,2,1,1,1,0], "test"
84+
pdu.add_variable_binding [1, 3, 6, 1, 2, 1, 1, 1, 0], "test"
8285

83-
assert_equal( SnmpGetResponse, pdu.to_ber_string )
86+
assert_equal(SnmpGetResponse, pdu.to_ber_string)
8487
end
8588

8689
def test_make_bad_response
@@ -94,20 +97,18 @@ def test_make_bad_response
9497

9598
def test_snmp_integers
9699
c32 = Net::SNMP::Counter32.new(100)
97-
assert_equal( "A\001d", c32.to_ber )
100+
assert_equal("A\001d", c32.to_ber)
98101
g32 = Net::SNMP::Gauge32.new(100)
99-
assert_equal( "B\001d", g32.to_ber )
102+
assert_equal("B\001d", g32.to_ber)
100103
t32 = Net::SNMP::TimeTicks32.new(100)
101-
assert_equal( "C\001d", t32.to_ber )
104+
assert_equal("C\001d", t32.to_ber)
102105
end
103106

104107
def test_community
105108
data = SnmpGetRequestXXX.dup
106109
ary = data.read_ber(Net::SNMP::AsnSyntax)
107-
pdu = Net::SnmpPdu.parse( ary )
108-
assert_equal( "xxxxxx", pdu.community )
110+
pdu = Net::SnmpPdu.parse(ary)
111+
assert_equal("xxxxxx", pdu.community)
109112
end
110113

111114
end
112-
113-

0 commit comments

Comments
 (0)