<?xml version="1.0" encoding="UTF-8" standalone="yes" ?>
<!DOCTYPE bugzilla SYSTEM "https://bugs.webkit.org/page.cgi?id=bugzilla.dtd">

<bugzilla version="5.0.4.1"
          urlbase="https://bugs.webkit.org/"
          
          maintainer="admin@webkit.org"
>

    <bug>
          <bug_id>61851</bug_id>
          
          <creation_ts>2011-06-01 03:01:11 -0700</creation_ts>
          <short_desc>WebSocket: WebSocketChannel::fail() should close the connection immediately</short_desc>
          <delta_ts>2011-06-01 19:53:31 -0700</delta_ts>
          <reporter_accessible>1</reporter_accessible>
          <cclist_accessible>1</cclist_accessible>
          <classification_id>1</classification_id>
          <classification>Unclassified</classification>
          <product>WebKit</product>
          <component>WebCore Misc.</component>
          <version>528+ (Nightly build)</version>
          <rep_platform>All</rep_platform>
          <op_sys>All</op_sys>
          <bug_status>RESOLVED</bug_status>
          <resolution>FIXED</resolution>
          
          
          <bug_file_loc></bug_file_loc>
          <status_whiteboard></status_whiteboard>
          <keywords></keywords>
          <priority>P2</priority>
          <bug_severity>Normal</bug_severity>
          <target_milestone>---</target_milestone>
          
          <blocked>61841</blocked>
          <everconfirmed>1</everconfirmed>
          <reporter name="Yuta Kitamura">yutak</reporter>
          <assigned_to name="Yuta Kitamura">yutak</assigned_to>
          <cc>ap</cc>
    
    <cc>commit-queue</cc>
    
    <cc>tkent</cc>
          

      

      

      

          <comment_sort_order>oldest_to_newest</comment_sort_order>  
          <long_desc isprivate="0" >
    <commentid>413252</commentid>
    <comment_count>0</comment_count>
    <who name="Yuta Kitamura">yutak</who>
    <bug_when>2011-06-01 03:01:11 -0700</bug_when>
    <thetext>Currently WebSocketChannel::fail() calls m_handle-&gt;close() instead of m_handle-&gt;disconnect().

This was a mistake, because m_handle-&gt;close() may not close the connection immediately if it has unsent data. m_handle-&gt;disconnect() should have been used, since it does exactly the same thing as what we want to do.

For details, see how *fail the WebSocket connection* and *close the WebSocket connection* is defined in the protocol specification.
http://tools.ietf.org/html/draft-ietf-hybi-thewebsocketprotocol-00#section-6</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>413263</commentid>
    <comment_count>1</comment_count>
      <attachid>95576</attachid>
    <who name="Yuta Kitamura">yutak</who>
    <bug_when>2011-06-01 03:31:17 -0700</bug_when>
    <thetext>Created attachment 95576
Patch</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>413785</commentid>
    <comment_count>2</comment_count>
      <attachid>95576</attachid>
    <who name="Kent Tamura">tkent</who>
    <bug_when>2011-06-01 17:36:01 -0700</bug_when>
    <thetext>Comment on attachment 95576
Patch

Looks ok.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>413849</commentid>
    <comment_count>3</comment_count>
      <attachid>95576</attachid>
    <who name="WebKit Commit Bot">commit-queue</who>
    <bug_when>2011-06-01 19:53:26 -0700</bug_when>
    <thetext>Comment on attachment 95576
Patch

Clearing flags on attachment: 95576

Committed r87876: &lt;http://trac.webkit.org/changeset/87876&gt;</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>413850</commentid>
    <comment_count>4</comment_count>
    <who name="WebKit Commit Bot">commit-queue</who>
    <bug_when>2011-06-01 19:53:31 -0700</bug_when>
    <thetext>All reviewed patches have been landed.  Closing bug.</thetext>
  </long_desc>
      
          <attachment
              isobsolete="0"
              ispatch="1"
              isprivate="0"
          >
            <attachid>95576</attachid>
            <date>2011-06-01 03:31:17 -0700</date>
            <delta_ts>2011-06-01 19:53:26 -0700</delta_ts>
            <desc>Patch</desc>
            <filename>bug-61851-20110601193115.patch</filename>
            <type>text/plain</type>
            <size>2210</size>
            <attacher name="Yuta Kitamura">yutak</attacher>
            
              <data encoding="base64">U3VidmVyc2lvbiBSZXZpc2lvbjogODc3NzEKZGlmZiAtLWdpdCBhL1NvdXJjZS9XZWJDb3JlL0No
YW5nZUxvZyBiL1NvdXJjZS9XZWJDb3JlL0NoYW5nZUxvZwppbmRleCA0ODM4YmM4MTRjOGY5MDQ1
MzQ1MzdlYWNmOTNhNWM0YjEwYjVkYzE2Li5iZTliM2RkZjY3NzIwYjM0NmMzOTlkOWIwZGUzYzQy
Yzk0MzQxMjZkIDEwMDY0NAotLS0gYS9Tb3VyY2UvV2ViQ29yZS9DaGFuZ2VMb2cKKysrIGIvU291
cmNlL1dlYkNvcmUvQ2hhbmdlTG9nCkBAIC0xLDMgKzEsMjMgQEAKKzIwMTEtMDYtMDEgIFl1dGEg
S2l0YW11cmEgIDx5dXRha0BjaHJvbWl1bS5vcmc+CisKKyAgICAgICAgUmV2aWV3ZWQgYnkgTk9C
T0RZIChPT1BTISkuCisKKyAgICAgICAgV2ViU29ja2V0OiBXZWJTb2NrZXRDaGFubmVsOjpmYWls
KCkgc2hvdWxkIGNsb3NlIHRoZSBjb25uZWN0aW9uIGltbWVkaWF0ZWx5CisgICAgICAgIGh0dHBz
Oi8vYnVncy53ZWJraXQub3JnL3Nob3dfYnVnLmNnaT9pZD02MTg1MQorCisgICAgICAgIFRoZSBl
ZmZlY3Qgb2YgdGhpcyBjaGFuZ2UgaXMgYWxtb3N0IHVub2JzZXJ2YWJsZS4gVGhlIGRpZmZlcmVu
Y2UgYmV0d2VlbiBtX2hhbmRsZS0+Y2xvc2UoKSBhbmQKKyAgICAgICAgbV9oYW5kbGUtPmRpc2Nv
bm5lY3QoKSBpcyB0aGF0IHRoZSBmb3JtZXIgZG9lcyBub3QgY2xvc2UgdGhlIGNvbm5lY3Rpb24g
aWYgdGhlIGhhbmRsZSBoYXMKKyAgICAgICAgdW5zZW50IGRhdGEgd2hpbGUgdGhlIGxhdHRlciBp
bW1lZGlhdGVseSBjbG9zZXMgdGhlIGNvbm5lY3Rpb24gcmVnYXJkbGVzcyBvZiB1bnNlbnQgZGF0
YS4KKyAgICAgICAgVXN1YWxseSBhIHNvY2tldCBzdHJlYW0gaGFuZGxlIGRvZXMgbm90IGhhdmUg
dW5zZW50IGRhdGEsIGFuZCBldmVuIGlmIGl0IGhhcyBhbnksIGl0IGlzIGhhcmQKKyAgICAgICAg
Zm9yIHVzZXIgc2NyaXB0cyB0byBvYnNlcnZlIHRoZSBkaWZmZXJlbmNlIGJldHdlZW4gY2xvc2Uo
KSBhbmQgZGlzY29ubmVjdCgpIChpdCBzaG91bGQgdGFrZSBzb21lIHRpbWUKKyAgICAgICAgZm9y
IG9uY2xvc2UoKSB0byBiZSBjYWxsZWQgaWYgdGhlcmUgYXJlIGFueSB1bnNlbnQgZGF0YSwgYnV0
IHRoZXJlIG91Z2h0IHRvIGJlIG5vIG90aGVyIGRpZmZlcmVuY2UKKyAgICAgICAgaW4gdXNlciBz
Y3JpcHRzJyBwZXJzcGVjdGl2ZSkuCisKKyAgICAgICAgTm8gbmV3IHRlc3RzIGFyZSBhZGRlZCwg
YmVjYXVzZSB3cml0aW5nIGEgdGVzdCBmb3IgdGhpcyBpc3N1ZSBpcyBub3QgZmVhc2libGUgZHVl
IHRvIHRoZSBhYm92ZSByZWFzb24uCisKKyAgICAgICAgKiB3ZWJzb2NrZXRzL1dlYlNvY2tldENo
YW5uZWwuY3BwOgorICAgICAgICAoV2ViQ29yZTo6V2ViU29ja2V0Q2hhbm5lbDo6ZmFpbCk6IFVz
ZSBtX2hhbmRsZS0+ZGlzY29ubmVjdCgpIGluc3RlYWQgb2YgbV9oYW5kbGUtPmNsb3NlKCkuCisK
IDIwMTEtMDUtMzEgIFlvbmcgTGkgIDx5b2xpQHJpbS5jb20+CiAKICAgICAgICAgUmV2aWV3ZWQg
YnkgRXJpYyBTZWlkZWwuCmRpZmYgLS1naXQgYS9Tb3VyY2UvV2ViQ29yZS93ZWJzb2NrZXRzL1dl
YlNvY2tldENoYW5uZWwuY3BwIGIvU291cmNlL1dlYkNvcmUvd2Vic29ja2V0cy9XZWJTb2NrZXRD
aGFubmVsLmNwcAppbmRleCAwYmU1NmUzNWE3ZTA1NmJjOTZjNjZmMmJhMWYxYjVhMTI2MGU0NTc0
Li42ZDQ5YTU2M2EwZGI5OGE5NGEzYzU0Y2JjMWYyMTUxM2Y4M2EzZWZhIDEwMDY0NAotLS0gYS9T
b3VyY2UvV2ViQ29yZS93ZWJzb2NrZXRzL1dlYlNvY2tldENoYW5uZWwuY3BwCisrKyBiL1NvdXJj
ZS9XZWJDb3JlL3dlYnNvY2tldHMvV2ViU29ja2V0Q2hhbm5lbC5jcHAKQEAgLTEzNiw3ICsxMzYs
NyBAQCB2b2lkIFdlYlNvY2tldENoYW5uZWw6OmZhaWwoY29uc3QgU3RyaW5nJiByZWFzb24pCiAg
ICAgaWYgKG1fY29udGV4dCkKICAgICAgICAgbV9jb250ZXh0LT5hZGRNZXNzYWdlKEpTTWVzc2Fn
ZVNvdXJjZSwgTG9nTWVzc2FnZVR5cGUsIEVycm9yTWVzc2FnZUxldmVsLCByZWFzb24sIDAsIG1f
aGFuZHNoYWtlLmNsaWVudE9yaWdpbigpLCAwKTsKICAgICBpZiAobV9oYW5kbGUgJiYgIW1fY2xv
c2VkKQotICAgICAgICBtX2hhbmRsZS0+Y2xvc2UoKTsgLy8gV2lsbCBjYWxsIGRpZENsb3NlKCku
CisgICAgICAgIG1faGFuZGxlLT5kaXNjb25uZWN0KCk7IC8vIFdpbGwgY2FsbCBkaWRDbG9zZSgp
LgogfQogCiB2b2lkIFdlYlNvY2tldENoYW5uZWw6OmRpc2Nvbm5lY3QoKQo=
</data>

          </attachment>
      

    </bug>

</bugzilla>