Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
dotNET Platform
runtime
提交
15033649
R
runtime
项目概览
dotNET Platform
/
runtime
11 个月 前同步成功
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
runtime
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
未验证
提交
15033649
编写于
11月 25, 2020
作者:
J
Justin Kotalik
提交者:
GitHub
11月 25, 2020
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Close accept loop when closing connection for Quic (#44885)
上级
31ffad2c
变更
6
显示空白变更内容
内联
并排
Showing
6 changed file
with
35 addition
and
14 deletion
+35
-14
src/libraries/System.Net.Quic/src/System/Net/Quic/Implementations/MsQuic/MsQuicConnection.cs
...ystem/Net/Quic/Implementations/MsQuic/MsQuicConnection.cs
+4
-6
src/libraries/System.Net.Quic/src/System/Net/Quic/Implementations/MsQuic/MsQuicListener.cs
.../System/Net/Quic/Implementations/MsQuic/MsQuicListener.cs
+9
-2
src/libraries/System.Net.Quic/src/System/Net/Quic/Implementations/MsQuic/MsQuicStream.cs
...rc/System/Net/Quic/Implementations/MsQuic/MsQuicStream.cs
+2
-2
src/libraries/System.Net.Quic/tests/FunctionalTests/MsQuicTests.cs
...ries/System.Net.Quic/tests/FunctionalTests/MsQuicTests.cs
+17
-0
src/libraries/System.Net.Quic/tests/FunctionalTests/QuicListenerTests.cs
...ystem.Net.Quic/tests/FunctionalTests/QuicListenerTests.cs
+3
-2
src/libraries/System.Net.Quic/tests/FunctionalTests/QuicStreamTests.cs
.../System.Net.Quic/tests/FunctionalTests/QuicStreamTests.cs
+0
-2
未找到文件。
src/libraries/System.Net.Quic/src/System/Net/Quic/Implementations/MsQuic/MsQuicConnection.cs
浏览文件 @
15033649
...
...
@@ -161,21 +161,21 @@ private uint HandleEventShutdownInitiatedByTransport(ref ConnectionEvent connect
_connectTcs
.
SetException
(
ExceptionDispatchInfo
.
SetCurrentStackTrace
(
ex
));
}
_acceptQueue
.
Writer
.
Complete
();
return
MsQuicStatusCodes
.
Success
;
}
private
uint
HandleEventShutdownInitiatedByPeer
(
ref
ConnectionEvent
connectionEvent
)
{
_abortErrorCode
=
connectionEvent
.
Data
.
ShutdownInitiatedByPeer
.
ErrorCode
;
_acceptQueue
.
Writer
.
Complete
();
return
MsQuicStatusCodes
.
Success
;
}
private
uint
HandleEventShutdownComplete
(
ref
ConnectionEvent
connectionEvent
)
{
_shutdownTcs
.
SetResult
(
MsQuicStatusCodes
.
Success
);
// Stop accepting new streams.
_acceptQueue
?.
Writer
.
Complete
();
return
MsQuicStatusCodes
.
Success
;
}
...
...
@@ -291,7 +291,7 @@ internal override ValueTask ConnectAsync(CancellationToken cancellationToken = d
private
void
SetCallbackHandler
()
{
Debug
.
Assert
(!
_handle
.
IsAllocated
);
Debug
.
Assert
(!
_handle
.
IsAllocated
,
"callback handler allocated already"
);
_handle
=
GCHandle
.
Alloc
(
this
);
MsQuicApi
.
Api
.
SetCallbackHandlerDelegate
(
...
...
@@ -310,8 +310,6 @@ private void SetCallbackHandler()
ErrorCode
);
QuicExceptionHelpers
.
ThrowIfFailed
(
status
,
"Failed to shutdown connection."
);
Debug
.
Assert
(
_shutdownTcs
.
Task
.
IsCompleted
==
false
);
return
new
ValueTask
(
_shutdownTcs
.
Task
);
}
...
...
src/libraries/System.Net.Quic/src/System/Net/Quic/Implementations/MsQuic/MsQuicListener.cs
浏览文件 @
15033649
...
...
@@ -34,7 +34,7 @@ internal sealed class MsQuicListener : QuicListenerProvider, IDisposable
private
QuicListenerOptions
_options
;
private
volatile
bool
_disposed
;
private
IPEndPoint
_listenEndPoint
;
private
bool
_started
;
private
readonly
Channel
<
MsQuicConnection
>
_acceptConnectionQueue
;
internal
MsQuicListener
(
QuicListenerOptions
options
)
...
...
@@ -120,6 +120,13 @@ internal override void Start()
{
ThrowIfDisposed
();
// protect against double starts.
if
(
_started
)
{
throw
new
QuicException
(
"Cannot start Listener multiple times"
);
}
_started
=
true
;
SetCallbackHandler
();
SOCKADDR_INET
address
=
MsQuicAddressHelpers
.
IPEndPointToINet
(
_listenEndPoint
);
...
...
@@ -202,7 +209,7 @@ private void StopAcceptingConnections()
internal
void
SetCallbackHandler
()
{
Debug
.
Assert
(!
_handle
.
IsAllocated
);
Debug
.
Assert
(!
_handle
.
IsAllocated
,
"listener allocated"
);
_handle
=
GCHandle
.
Alloc
(
this
);
MsQuicApi
.
Api
.
SetCallbackHandlerDelegate
(
...
...
src/libraries/System.Net.Quic/src/System/Net/Quic/Implementations/MsQuic/MsQuicStream.cs
浏览文件 @
15033649
...
...
@@ -71,7 +71,7 @@ internal sealed class MsQuicStream : QuicStreamProvider
// Creates a new MsQuicStream
internal
MsQuicStream
(
MsQuicConnection
connection
,
QUIC_STREAM_OPEN_FLAG
flags
,
IntPtr
nativeObjPtr
,
bool
inbound
)
{
Debug
.
Assert
(
connection
!=
null
);
Debug
.
Assert
(
connection
!=
null
,
"Connection null"
);
_ptr
=
nativeObjPtr
;
...
...
@@ -936,7 +936,7 @@ private void SetCallbackHandler()
/// </summary>
private
void
StartLocalStream
()
{
Debug
.
Assert
(!
_started
);
Debug
.
Assert
(!
_started
,
"start local stream"
);
uint
status
=
MsQuicApi
.
Api
.
StreamStartDelegate
(
_ptr
,
(
uint
)
QUIC_STREAM_START_FLAG
.
ASYNC
);
...
...
src/libraries/System.Net.Quic/tests/FunctionalTests/MsQuicTests.cs
浏览文件 @
15033649
...
...
@@ -177,6 +177,23 @@ public async Task CallDifferentWriteMethodsWorks()
Assert
.
Equal
(
24
,
res
);
}
[
Fact
]
public
async
Task
CloseAsync_ByServer_AcceptThrows
()
{
await
RunClientServer
(
clientConnection
=>
{
return
Task
.
CompletedTask
;
},
async
serverConnection
=>
{
var
acceptTask
=
serverConnection
.
AcceptStreamAsync
();
await
serverConnection
.
CloseAsync
(
errorCode
:
0
);
// make sure
await
Assert
.
ThrowsAsync
<
QuicOperationAbortedException
>(()
=>
acceptTask
.
AsTask
());
});
}
private
static
ReadOnlySequence
<
byte
>
CreateReadOnlySequenceFromBytes
(
byte
[]
data
)
{
List
<
byte
[
]>
segments
=
new
List
<
byte
[
]>
...
...
src/libraries/System.Net.Quic/tests/FunctionalTests/QuicListenerTests.cs
浏览文件 @
15033649
...
...
@@ -21,10 +21,11 @@ public async Task Listener_Backlog_Success()
using
QuicListener
listener
=
CreateQuicListener
();
using
QuicConnection
clientConnection
=
CreateQuicConnection
(
listener
.
ListenEndPoint
);
await
clientConnection
.
ConnectAsync
();
var
clientStreamTask
=
clientConnection
.
ConnectAsync
();
using
QuicConnection
serverConnection
=
await
listener
.
AcceptConnectionAsync
();
}).
TimeoutAfter
(
millisecondsTimeout
:
5
_000
);
await
clientStreamTask
;
}).
TimeoutAfter
(
millisecondsTimeout
:
6
_000
);
}
}
...
...
src/libraries/System.Net.Quic/tests/FunctionalTests/QuicStreamTests.cs
浏览文件 @
15033649
...
...
@@ -305,8 +305,6 @@ public async Task LargeDataSentAndReceived()
}
}
[
Fact
]
public
async
Task
TestStreams
()
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录