aboutsummaryrefslogtreecommitdiff
path: root/openssl/src/ssl/tests.rs
diff options
context:
space:
mode:
authorSteven Fackler <[email protected]>2015-05-05 22:57:14 -0400
committerSteven Fackler <[email protected]>2015-05-05 22:57:14 -0400
commit8a9aa0c657d61cc2a32a1d59dcbd2a55d6f9b694 (patch)
tree441f3538fe7f7b1976c5d377af68c409efdd2267 /openssl/src/ssl/tests.rs
parentMerge pull request #201 from manuels/pkey_cmp (diff)
parentAdd SslStream.pending() (diff)
downloadrust-openssl-8a9aa0c657d61cc2a32a1d59dcbd2a55d6f9b694.tar.xz
rust-openssl-8a9aa0c657d61cc2a32a1d59dcbd2a55d6f9b694.zip
Merge pull request #210 from manuels/pending
Add SslStream.pending()
Diffstat (limited to 'openssl/src/ssl/tests.rs')
-rw-r--r--openssl/src/ssl/tests.rs24
1 files changed, 24 insertions, 0 deletions
diff --git a/openssl/src/ssl/tests.rs b/openssl/src/ssl/tests.rs
index e6af551b..c9a2d73a 100644
--- a/openssl/src/ssl/tests.rs
+++ b/openssl/src/ssl/tests.rs
@@ -337,6 +337,30 @@ fn test_read() {
io::copy(&mut stream, &mut io::sink()).ok().expect("read error");
}
+
+#[test]
+fn test_pending() {
+ let tcp = TcpStream::connect("127.0.0.1:15418").unwrap();
+ let mut stream = SslStream::new(&SslContext::new(Sslv23).unwrap(), tcp).unwrap();
+ stream.write_all("GET /\r\n\r\n".as_bytes()).unwrap();
+ stream.flush().unwrap();
+
+ // wait for the response and read first byte...
+ let mut buf = [0u8; 16*1024];
+ stream.read(&mut buf[..1]).unwrap();
+
+ let pending = stream.pending();
+ let len = stream.read(&mut buf[1..]).unwrap();
+
+ assert_eq!(pending, len);
+
+ stream.read(&mut buf[..1]).unwrap();
+
+ let pending = stream.pending();
+ let len = stream.read(&mut buf[1..]).unwrap();
+ assert_eq!(pending, len);
+}
+
/// Tests that connecting with the client using NPN, but the server not does not
/// break the existing connection behavior.
#[test]