|
1 | 1 | require 'spec_helper' |
2 | 2 |
|
| 3 | +describe Net::LDAP do |
| 4 | + describe "initialize" do |
| 5 | + context "on instrumentation_service configuration" do |
| 6 | + before do |
| 7 | + @tcp_socket = flexmock(:connection) |
| 8 | + @tcp_socket.should_receive(:close) |
| 9 | + flexmock(TCPSocket).should_receive(:new).and_return(@tcp_socket) |
| 10 | + @service = MockInstrumentationService.new |
| 11 | + end |
| 12 | + |
| 13 | + it "should set the service object and instrument network calls" do |
| 14 | + ldap = Net::LDAP.new(:server => 'test.mocked.com', :port => 636, |
| 15 | + :instrumentation_service => @service) |
| 16 | + |
| 17 | + @tcp_socket.should_receive(:write) |
| 18 | + |
| 19 | + ber = Net::BER::BerIdentifiedArray.new([0, "", ""]) |
| 20 | + ber.ber_identifier = 7 |
| 21 | + result = [2, ber] |
| 22 | + @tcp_socket.should_receive(:read_ber).and_return(result) |
| 23 | + |
| 24 | + ldap.bind.should be_true |
| 25 | + |
| 26 | + # a write event, then a read event |
| 27 | + @service.events.size.should == 2 |
| 28 | + end |
| 29 | + end |
| 30 | + end |
| 31 | +end |
| 32 | + |
3 | 33 | describe Net::LDAP::Connection do |
4 | 34 | describe "initialize" do |
5 | 35 | context "when host is not responding" do |
|
77 | 107 | end |
78 | 108 |
|
79 | 109 | context "instrumentation" do |
80 | | - class InstrumentationService |
81 | | - attr_reader :events |
82 | | - |
83 | | - def initialize |
84 | | - @events = [] |
85 | | - end |
86 | | - |
87 | | - def instrument(event, payload) |
88 | | - result = yield |
89 | | - @events << [event, payload, result] |
90 | | - result |
91 | | - end |
92 | | - end |
93 | | - |
94 | 110 | before do |
95 | 111 | @tcp_socket = flexmock(:connection) |
96 | 112 | @tcp_socket.should_receive(:write) |
97 | 113 | flexmock(TCPSocket).should_receive(:new).and_return(@tcp_socket) |
98 | | - @service = InstrumentationService.new |
| 114 | + @service = MockInstrumentationService.new |
99 | 115 | end |
100 | 116 |
|
101 | 117 | subject do |
|
0 commit comments