diff options
| author | wangjohn <wangjohn@mit.edu> | 2013-07-14 18:48:57 -0400 | 
|---|---|---|
| committer | wangjohn <wangjohn@mit.edu> | 2013-07-30 03:23:01 -0400 | 
| commit | d2d6aef51000f90f68db6d46fe59533f522fa25a (patch) | |
| tree | 1a77129cfd60b684513a8603174cca18bedd10fb /actionpack/test/controller | |
| parent | 42f01e94e231763c10d2c1e0977c6ec5b5a7c78a (diff) | |
| download | rails-d2d6aef51000f90f68db6d46fe59533f522fa25a.tar.gz rails-d2d6aef51000f90f68db6d46fe59533f522fa25a.tar.bz2 rails-d2d6aef51000f90f68db6d46fe59533f522fa25a.zip | |
Creating an SSE class to be used with ActionController::Live.
Diffstat (limited to 'actionpack/test/controller')
| -rw-r--r-- | actionpack/test/controller/live_stream_test.rb | 88 | 
1 files changed, 88 insertions, 0 deletions
| diff --git a/actionpack/test/controller/live_stream_test.rb b/actionpack/test/controller/live_stream_test.rb index 34164a19f0..0a25b5fa28 100644 --- a/actionpack/test/controller/live_stream_test.rb +++ b/actionpack/test/controller/live_stream_test.rb @@ -2,6 +2,94 @@ require 'abstract_unit'  require 'active_support/concurrency/latch'  module ActionController +  class SSETest < ActionController::TestCase +    class SSETestController < ActionController::Base +      include ActionController::Live + +      def basic_sse +        response.headers['Content-Type'] = 'text/event-stream' +        sse = SSE.new(response.stream) +        sse.write("{\"name\":\"John\"}") +        sse.write({ name: "Ryan" }) +      ensure +        sse.close +      end + +      def sse_with_event +        sse = SSE.new(response.stream, event: "send-name") +        sse.write("{\"name\":\"John\"}") +        sse.write({ name: "Ryan" }) +      ensure +        sse.close +      end + +      def sse_with_retry +        sse = SSE.new(response.stream, retry: 1000) +        sse.write("{\"name\":\"John\"}") +        sse.write({ name: "Ryan" }, retry: 1500) +      ensure +        sse.close +      end + +      def sse_with_id +        sse = SSE.new(response.stream) +        sse.write("{\"name\":\"John\"}", id: 1) +        sse.write({ name: "Ryan" }, id: 2) +      ensure +        sse.close +      end +    end + +    tests SSETestController + +    def wait_for_response_stream_close +      while !response.stream.closed? +        sleep 0.01 +      end +    end + +    def test_basic_sse +      get :basic_sse + +      wait_for_response_stream_close +      assert_match(/data: {\"name\":\"John\"}/, response.body) +      assert_match(/data: {\"name\":\"Ryan\"}/, response.body) +    end + +    def test_sse_with_event_name +      get :sse_with_event + +      wait_for_response_stream_close +      assert_match(/data: {\"name\":\"John\"}/, response.body) +      assert_match(/data: {\"name\":\"Ryan\"}/, response.body) +      assert_match(/event: send-name/, response.body) +    end + +    def test_sse_with_retry +      get :sse_with_retry + +      wait_for_response_stream_close +      first_response, second_response = response.body.split("\n\n") +      assert_match(/data: {\"name\":\"John\"}/, first_response) +      assert_match(/retry: 1000/, first_response) + +      assert_match(/data: {\"name\":\"Ryan\"}/, second_response) +      assert_match(/retry: 1500/, second_response) +    end + +    def test_sse_with_id +      get :sse_with_id + +      wait_for_response_stream_close +      first_response, second_response = response.body.split("\n\n") +      assert_match(/data: {\"name\":\"John\"}/, first_response) +      assert_match(/id: 1/, first_response) + +      assert_match(/data: {\"name\":\"Ryan\"}/, second_response) +      assert_match(/id: 2/, second_response) +    end +  end +    class LiveStreamTest < ActionController::TestCase      class TestController < ActionController::Base        include ActionController::Live | 
