You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
187 lines
6.0 KiB
187 lines
6.0 KiB
4 months ago
|
#!/usr/bin/env node
|
||
|
|
||
|
/*
|
||
|
* Protocol Buffers - Google's data interchange format
|
||
|
* Copyright 2008 Google Inc. All rights reserved.
|
||
|
* https://developers.google.com/protocol-buffers/
|
||
|
*
|
||
|
* Redistribution and use in source and binary forms, with or without
|
||
|
* modification, are permitted provided that the following conditions are
|
||
|
* met:
|
||
|
*
|
||
|
* * Redistributions of source code must retain the above copyright
|
||
|
* notice, this list of conditions and the following disclaimer.
|
||
|
* * Redistributions in binary form must reproduce the above
|
||
|
* copyright notice, this list of conditions and the following disclaimer
|
||
|
* in the documentation and/or other materials provided with the
|
||
|
* distribution.
|
||
|
* * Neither the name of Google Inc. nor the names of its
|
||
|
* contributors may be used to endorse or promote products derived from
|
||
|
* this software without specific prior written permission.
|
||
|
*
|
||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||
|
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||
|
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||
|
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||
|
*/
|
||
|
|
||
|
var conformance = require('conformance_pb');
|
||
|
var test_messages_proto3 = require('google/protobuf/test_messages_proto3_pb');
|
||
|
var test_messages_proto2 = require('google/protobuf/test_messages_proto2_pb');
|
||
|
var fs = require('fs');
|
||
|
|
||
|
var testCount = 0;
|
||
|
|
||
|
function doTest(request) {
|
||
|
var testMessage;
|
||
|
var response = new conformance.ConformanceResponse();
|
||
|
|
||
|
try {
|
||
|
if (request.getRequestedOutputFormat() === conformance.WireFormat.JSON) {
|
||
|
response.setSkipped("JSON not supported.");
|
||
|
return response;
|
||
|
}
|
||
|
|
||
|
switch (request.getPayloadCase()) {
|
||
|
case conformance.ConformanceRequest.PayloadCase.PROTOBUF_PAYLOAD: {
|
||
|
if (request.getMessageType() == "protobuf_test_messages.proto3.TestAllTypesProto3") {
|
||
|
try {
|
||
|
testMessage = test_messages_proto3.TestAllTypesProto3.deserializeBinary(
|
||
|
request.getProtobufPayload());
|
||
|
} catch (err) {
|
||
|
response.setParseError(err.toString());
|
||
|
return response;
|
||
|
}
|
||
|
} else if (request.getMessageType() == "protobuf_test_messages.proto2.TestAllTypesProto2"){
|
||
|
try {
|
||
|
testMessage = test_messages_proto2.TestAllTypesProto2.deserializeBinary(
|
||
|
request.getProtobufPayload());
|
||
|
} catch (err) {
|
||
|
response.setParseError(err.toString());
|
||
|
return response;
|
||
|
}
|
||
|
} else {
|
||
|
throw "Protobuf request doesn\'t have specific payload type";
|
||
|
}
|
||
|
}
|
||
|
|
||
|
case conformance.ConformanceRequest.PayloadCase.JSON_PAYLOAD:
|
||
|
response.setSkipped("JSON not supported.");
|
||
|
return response;
|
||
|
|
||
|
case conformance.ConformanceRequest.PayloadCase.TEXT_PAYLOAD:
|
||
|
response.setSkipped("Text format not supported.");
|
||
|
return response;
|
||
|
|
||
|
case conformance.ConformanceRequest.PayloadCase.PAYLOAD_NOT_SET:
|
||
|
response.setRuntimeError("Request didn't have payload");
|
||
|
return response;
|
||
|
}
|
||
|
|
||
|
switch (request.getRequestedOutputFormat()) {
|
||
|
case conformance.WireFormat.UNSPECIFIED:
|
||
|
response.setRuntimeError("Unspecified output format");
|
||
|
return response;
|
||
|
|
||
|
case conformance.WireFormat.PROTOBUF:
|
||
|
response.setProtobufPayload(testMessage.serializeBinary());
|
||
|
|
||
|
case conformance.WireFormat.JSON:
|
||
|
response.setSkipped("JSON not supported.");
|
||
|
return response;
|
||
|
|
||
|
default:
|
||
|
throw "Request didn't have requested output format";
|
||
|
}
|
||
|
} catch (err) {
|
||
|
response.setRuntimeError(err.toString());
|
||
|
}
|
||
|
|
||
|
return response;
|
||
|
}
|
||
|
|
||
|
function onEof(totalRead) {
|
||
|
if (totalRead == 0) {
|
||
|
return undefined;
|
||
|
} else {
|
||
|
throw "conformance_nodejs: premature EOF on stdin.";
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Utility function to read a buffer of N bytes.
|
||
|
function readBuffer(bytes) {
|
||
|
var buf = new Buffer(bytes);
|
||
|
var totalRead = 0;
|
||
|
while (totalRead < bytes) {
|
||
|
var read = 0;
|
||
|
try {
|
||
|
read = fs.readSync(process.stdin.fd, buf, totalRead, bytes - totalRead);
|
||
|
} catch (e) {
|
||
|
if (e.code == 'EOF') {
|
||
|
return onEof(totalRead)
|
||
|
} else if (e.code == 'EAGAIN') {
|
||
|
} else {
|
||
|
throw "conformance_nodejs: Error reading from stdin." + e;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
totalRead += read;
|
||
|
}
|
||
|
|
||
|
return buf;
|
||
|
}
|
||
|
|
||
|
function writeBuffer(buffer) {
|
||
|
var totalWritten = 0;
|
||
|
while (totalWritten < buffer.length) {
|
||
|
totalWritten += fs.writeSync(
|
||
|
process.stdout.fd, buffer, totalWritten, buffer.length - totalWritten);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Returns true if the test ran successfully, false on legitimate EOF.
|
||
|
// If EOF is encountered in an unexpected place, raises IOError.
|
||
|
function doTestIo() {
|
||
|
var lengthBuf = readBuffer(4);
|
||
|
if (!lengthBuf) {
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
var length = lengthBuf.readInt32LE(0);
|
||
|
var serializedRequest = readBuffer(length);
|
||
|
if (!serializedRequest) {
|
||
|
throw "conformance_nodejs: Failed to read request.";
|
||
|
}
|
||
|
|
||
|
serializedRequest = new Uint8Array(serializedRequest);
|
||
|
var request =
|
||
|
conformance.ConformanceRequest.deserializeBinary(serializedRequest);
|
||
|
var response = doTest(request);
|
||
|
|
||
|
var serializedResponse = response.serializeBinary();
|
||
|
|
||
|
lengthBuf = new Buffer(4);
|
||
|
lengthBuf.writeInt32LE(serializedResponse.length, 0);
|
||
|
writeBuffer(lengthBuf);
|
||
|
writeBuffer(new Buffer(serializedResponse));
|
||
|
|
||
|
testCount += 1
|
||
|
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
while (true) {
|
||
|
if (!doTestIo()) {
|
||
|
console.error('conformance_nodejs: received EOF from test runner ' +
|
||
|
"after " + testCount + " tests, exiting")
|
||
|
break;
|
||
|
}
|
||
|
}
|