| 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 |