blob: 35f2cef30a1e3dcc53b7b395dc57ecdf0c3f284f [file] [log] [blame]
// Copyright (c) 2016, the Dart project authors. Please see the AUTHORS file
// for details. All rights reserved. Use of this source code is governed by a
// BSD-style license that can be found in the LICENSE file.
import "dart:async";
import "dart:io";
testAddressParse() async {
print(new InternetAddress("1.0.2.3").rawAddress);
print(new InternetAddress("1.0.2.3").type);
print(new InternetAddress("::1").rawAddress);
print(new InternetAddress("::1").type);
try {
print(new InternetAddress("localhost"));
} catch (e) {
print(e);
}
}
testSimpleBind() async {
var s = await RawServerSocket.bind(InternetAddress.LOOPBACK_IP_V4, 0);
print("port = ${s.port}");
await s.close();
}
testSimpleConnect() async {
var server = await RawServerSocket.bind(InternetAddress.LOOPBACK_IP_V4, 0);
print("server port = ${server.port}");
server.listen((socket) {
print("listen socket port = ${socket.port}");
socket.close();
});
var socket = await RawSocket.connect("127.0.0.1", server.port);
print("socket port = ${socket.port}");
if (socket.remoteAddress.address != "127.0.0.1" ||
socket.remoteAddress.type != InternetAddressType.IP_V4) {
throw "Bad remote address ${socket.remoteAddress}";
}
if (socket.remotePort is! int) {
throw "Bad remote port ${socket.remotePort}";
}
await server.close();
await socket.close();
}
testSimpleReadWriteClose() async {
// This test creates a server and a client connects. The client then
// writes and the server echos. When the client finishes fully reading the
// echo, it closes the socket. When the server receives the close event, it
// closes its end of the socket too.
const messageSize = 1000;
int serverReadCount = 0;
int clientReadCount = 0;
List<int> createTestData() {
return new List<int>.generate(messageSize, (index) => index & 0xff);
}
void verifyTestData(List<int> data) {
assert(messageSize == data.length);
List<int> expected = createTestData();
for (int i = 0; i < messageSize; i++) {
assert(expected[i] == data[i]);
}
}
var server = await RawServerSocket.bind(InternetAddress.LOOPBACK_IP_V4, 0);
server.listen((client) {
int bytesRead = 0;
int bytesWritten = 0;
bool closedEventReceived = false;
List<int> data = new List<int>(messageSize);
bool doneReading = false;
client.writeEventsEnabled = false;
client.listen((event) {
switch (event) {
case RawSocketEvent.READ:
if (doneReading) {
break;
}
print("client READ event bytesRead = $bytesRead");
assert(bytesWritten == 0);
assert(client.available() > 0);
var buffer = client.read(200);
print("client READ event: read ${buffer.length} more bytes");
data.setRange(bytesRead, bytesRead + buffer.length, buffer);
bytesRead += buffer.length;
if (bytesRead == data.length) {
verifyTestData(data);
print("client READ event. Done reading, enabling writes");
client.writeEventsEnabled = true;
doneReading = true;
}
break;
case RawSocketEvent.WRITE:
assert(!client.writeEventsEnabled);
bytesWritten += client.write(
data, bytesWritten, data.length - bytesWritten);
print("client WRITE event: $bytesWritten written");
if (bytesWritten < data.length) {
client.writeEventsEnabled = true;
}
if (bytesWritten == data.length) {
print("client WRITE event: done writing.");
}
break;
case RawSocketEvent.READ_CLOSED:
print("client READ_CLOSED event");
client.close();
server.close();
break;
case RawSocketEvent.CLOSED:
assert(!closedEventReceived);
print("client CLOSED event");
closedEventReceived = true;
break;
default: throw "Unexpected event $event";
}
},
onError: (e) { print("client ERROR $e"); },
onDone: () {assert(closedEventReceived);});
});
{
var completer = new Completer();
var socket = await RawSocket.connect("127.0.0.1", server.port);
int bytesRead = 0;
int bytesWritten = 0;
bool closedEventReceived = false;
List<int> data = createTestData();
socket.listen((event) {
switch (event) {
case RawSocketEvent.READ:
assert(socket.available() > 0);
print("server READ event: ${bytesRead} read");
var buffer = socket.read();
print("server READ event: read ${buffer.length} more bytes");
data.setRange(bytesRead, bytesRead + buffer.length, buffer);
bytesRead += buffer.length;
if (bytesRead == messageSize) {
print("server READ event: done reading");
socket.close();
}
break;
case RawSocketEvent.WRITE:
assert(bytesRead == 0);
assert(!socket.writeEventsEnabled);
bytesWritten += socket.write(
data, bytesWritten, data.length - bytesWritten);
print("server WRITE event: ${bytesWritten} written");
if (bytesWritten < data.length) {
socket.writeEventsEnabled = true;
} else {
print("server WRITE event: done writing");
data = new List<int>(messageSize);
}
break;
case RawSocketEvent.READ_CLOSED:
print("server READ_CLOSED event");
verifyTestData(data);
socket.close();
break;
case RawSocketEvent.CLOSED:
assert(!closedEventReceived);
print("server CLOSED event");
closedEventReceived = true;
break;
default: throw "Unexpected event $event";
}
},
onError: (e) { print("server ERROR $e"); },
onDone: () {
assert(closedEventReceived);
completer.complete(null);
});
return completer.future;
}
}
testSimpleReadWriteShutdown({bool dropReads}) async {
// This test creates a server and a client connects. The client then
// writes and the server echos. When the server has finished its
// echo it half-closes. When the client gets the close event is
// closes fully.
const messageSize = 1000;
int serverReadCount = 0;
int clientReadCount = 0;
List<int> createTestData() {
return new List<int>.generate(messageSize, (index) => index & 0xff);
}
void verifyTestData(List<int> data) {
assert(messageSize == data.length);
List<int> expected = createTestData();
for (int i = 0; i < messageSize; i++) {
assert(expected[i] == data[i]);
}
}
var server = await RawServerSocket.bind(InternetAddress.LOOPBACK_IP_V4, 0);
server.listen((client) {
int bytesRead = 0;
int bytesWritten = 0;
bool closedEventReceived = false;
List<int> data = new List<int>(messageSize);
bool doneReading = false;
client.writeEventsEnabled = false;
client.listen((event) {
switch (event) {
case RawSocketEvent.READ:
if (doneReading) {
break;
}
if (dropReads) {
if (serverReadCount != 10) {
serverReadCount++;
break;
} else {
serverReadCount = 0;
}
}
print("client READ event bytesRead = $bytesRead");
assert(bytesWritten == 0);
assert(client.available() > 0);
var buffer = client.read(200);
print("client READ event: read ${buffer.length} more bytes");
data.setRange(bytesRead, bytesRead + buffer.length, buffer);
bytesRead += buffer.length;
if (bytesRead == data.length) {
verifyTestData(data);
print("client READ event. Done reading, enabling writes");
client.writeEventsEnabled = true;
doneReading = true;
}
break;
case RawSocketEvent.WRITE:
assert(!client.writeEventsEnabled);
bytesWritten += client.write(
data, bytesWritten, data.length - bytesWritten);
print("client WRITE event: $bytesWritten written");
if (bytesWritten < data.length) {
client.writeEventsEnabled = true;
}
if (bytesWritten == data.length) {
print("client WRITE event: done writing.");
client.shutdown(SocketDirection.SEND);
}
break;
case RawSocketEvent.READ_CLOSED:
print("client READ_CLOSED event");
server.close();
break;
case RawSocketEvent.CLOSED:
assert(!closedEventReceived);
print("client CLOSED event");
closedEventReceived = true;
break;
default: throw "Unexpected event $event";
}
},
onDone: () {assert(closedEventReceived);});
});
{
var completer = new Completer();
var socket = await RawSocket.connect("127.0.0.1", server.port);
int bytesRead = 0;
int bytesWritten = 0;
bool closedEventReceived = false;
List<int> data = createTestData();
socket.listen((event) {
switch (event) {
case RawSocketEvent.READ:
assert(socket.available() > 0);
if (dropReads) {
if (clientReadCount != 10) {
clientReadCount++;
break;
} else {
clientReadCount = 0;
}
}
print("server READ event: ${bytesRead} read");
var buffer = socket.read();
print("server READ event: read ${buffer.length} more bytes");
data.setRange(bytesRead, bytesRead + buffer.length, buffer);
bytesRead += buffer.length;
break;
case RawSocketEvent.WRITE:
assert(bytesRead == 0);
assert(!socket.writeEventsEnabled);
bytesWritten += socket.write(
data, bytesWritten, data.length - bytesWritten);
print("server WRITE event: ${bytesWritten} written");
if (bytesWritten < data.length) {
socket.writeEventsEnabled = true;
} else {
print("server WRITE event: done writing");
data = new List<int>(messageSize);
}
break;
case RawSocketEvent.READ_CLOSED:
print("server READ_CLOSED event");
verifyTestData(data);
socket.close();
break;
case RawSocketEvent.CLOSED:
assert(!closedEventReceived);
print("server CLOSED event");
closedEventReceived = true;
break;
default: throw "Unexpected event $event";
}
},
onDone: () {
assert(closedEventReceived);
completer.complete(null);
});
return completer.future;
}
}
Future testGoogleHttp(SecurityContext context, String outcome) async {
var client = new HttpClient(context: context);
try {
// First, check if the lookup works.
var address = await InternetAddress.lookup('www.google.com');
print(address);
var request = await client.getUrl(Uri.parse('http://www.google.com/'));
request.followRedirects = false;
var response = await request.close();
assert('pass' == outcome);
try { await response.drain(); } catch (e) {
print('drain failed: $e');
}
} catch (e) {
// Lookup failed or connection failed. Don't report a failure.
print("SocketException: $e");
} finally {
client.close();
}
}
Future testGoogleHttps(SecurityContext context, String outcome) async {
// If this isn't reasonable, the certificate will be rejected.
print(new DateTime.now());
var client = new HttpClient(context: context);
// We need to use an external server that is backed by a
// built-in root certificate authority.
try {
// First, check if the lookup works.
var address = await InternetAddress.lookup('www.google.com');
print(address);
var request = await client.getUrl(Uri.parse('https://www.google.com/'));
request.followRedirects = false;
var response = await request.close();
assert('pass' == outcome);
try { await response.drain(); } catch (e) {
print('drain failed: $e');
}
} catch (e) {
// Lookup failed or connection failed. Don't report a failure.
print("SocketException: $e");
} finally {
client.close();
}
}
main() async {
print("Hello, Fuchsia!");
print("testAddressParse");
await testAddressParse();
print("testAddressParse done");
print("testSimpleBind");
await testSimpleBind();
print("testSimpleBind done");
print("testSimpleConnect");
await testSimpleConnect();
print("testSimpleConnect done");
print("testSimpleReadWriteClose");
await testSimpleReadWriteClose();
print("testSimpleReadWriteClose done");
print("testSimpleReadWriteShutdown");
await testSimpleReadWriteShutdown(dropReads: false);
print("testSimpleReadWriteShutdown done");
print("testGoogleHttp");
await testGoogleHttp(null, 'pass');
print("testGoogleHttp done");
print("testGoogleHttps");
await testGoogleHttps(null, 'pass');
print("testGoogleHttps done");
print("Goodbyte, Fuchsia!");
}