OLD | NEW |
1 # Copyright 2010, Google Inc. | 1 # Copyright 2015, Google Inc. |
2 # All rights reserved. | 2 # All rights reserved. |
3 # | 3 # |
4 # Redistribution and use in source and binary forms, with or without | 4 # Redistribution and use in source and binary forms, with or without |
5 # modification, are permitted provided that the following conditions are | 5 # modification, are permitted provided that the following conditions are |
6 # met: | 6 # met: |
7 # | 7 # |
8 # * Redistributions of source code must retain the above copyright | 8 # * Redistributions of source code must retain the above copyright |
9 # notice, this list of conditions and the following disclaimer. | 9 # notice, this list of conditions and the following disclaimer. |
10 # * Redistributions in binary form must reproduce the above | 10 # * Redistributions in binary form must reproduce the above |
11 # copyright notice, this list of conditions and the following disclaimer | 11 # copyright notice, this list of conditions and the following disclaimer |
12 # in the documentation and/or other materials provided with the | 12 # in the documentation and/or other materials provided with the |
13 # distribution. | 13 # distribution. |
14 # * Neither the name of Google Inc. nor the names of its | 14 # * Neither the name of Google Inc. nor the names of its |
15 # contributors may be used to endorse or promote products derived from | 15 # contributors may be used to endorse or promote products derived from |
16 # this software without specific prior written permission. | 16 # this software without specific prior written permission. |
17 # | 17 # |
18 # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | 18 # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
19 # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | 19 # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
20 # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | 20 # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
21 # A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | 21 # A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
22 # OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | 22 # OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
23 # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | 23 # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
24 # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | 24 # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
25 # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | 25 # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
26 # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 26 # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
27 # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 27 # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
28 # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 28 # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
29 | 29 |
| 30 spec_dir = File.expand_path(File.dirname(__FILE__)) |
| 31 root_dir = File.expand_path(File.join(spec_dir, '..')) |
| 32 lib_dir = File.expand_path(File.join(root_dir, 'lib')) |
30 | 33 |
31 from mod_pywebsocket import msgutil | 34 $LOAD_PATH.unshift(spec_dir) |
| 35 $LOAD_PATH.unshift(lib_dir) |
| 36 $LOAD_PATH.uniq! |
32 | 37 |
| 38 # set up coverage |
| 39 require 'simplecov' |
| 40 SimpleCov.start do |
| 41 add_filter 'spec' |
| 42 add_filter 'bin' |
| 43 SimpleCov.command_name ENV['COVERAGE_NAME'] |
| 44 end if ENV['COVERAGE_NAME'] |
33 | 45 |
34 _GOODBYE_MESSAGE = 'Goodbye' | 46 require 'rspec' |
| 47 require 'logging' |
| 48 require 'rspec/logging_helper' |
35 | 49 |
| 50 # GRPC is the general RPC module |
| 51 # |
| 52 # Configure its logging for fine-grained log control during test runs |
| 53 module GRPC |
| 54 extend Logging.globally |
| 55 end |
| 56 Logging.logger.root.appenders = Logging.appenders.stdout |
| 57 Logging.logger.root.level = :info |
| 58 Logging.logger['GRPC'].level = :info |
| 59 Logging.logger['GRPC::ActiveCall'].level = :info |
| 60 Logging.logger['GRPC::BidiCall'].level = :info |
36 | 61 |
37 def web_socket_do_extra_handshake(request): | 62 # Configure RSpec to capture log messages for each test. The output from the |
38 pass # Always accept. | 63 # logs will be stored in the @log_output variable. It is a StringIO instance. |
| 64 RSpec.configure do |config| |
| 65 include RSpec::LoggingHelper |
| 66 config.capture_log_messages # comment this out to see logs during test runs |
| 67 end |
39 | 68 |
40 | 69 RSpec::Expectations.configuration.warn_about_potential_false_positives = false |
41 def web_socket_transfer_data(request): | |
42 while True: | |
43 line = msgutil.receive_message(request) | |
44 msgutil.send_message(request, line) | |
45 if line == _GOODBYE_MESSAGE: | |
46 return | |
OLD | NEW |