add EncodingTest. sbt still not configured quite right

This commit is contained in:
David Renshaw 2014-05-26 16:09:50 -04:00
parent 553cdafe13
commit d5de5f6419
6 changed files with 75 additions and 40 deletions

View file

@ -0,0 +1,16 @@
package org.capnproto;
import org.capnproto.test.Test._;
import org.scalatest.FunSuite
class EncodingSuite extends FunSuite {
test("AllTypes") {
val message = new MessageBuilder();
val allTypes = message.initRoot(TestAllTypes.Builder.factory);
allTypes.setVoidField();
allTypes.setBoolField(true);
}
}

View file

@ -2,6 +2,7 @@
using Java = import "/java_support/java.capnp"; using Java = import "/java_support/java.capnp";
$Java.package("org.capnproto.test"); $Java.package("org.capnproto.test");
$Java.outerClassname("Test");
enum TestEnum { enum TestEnum {
foo @0; foo @0;
@ -14,6 +15,22 @@ enum TestEnum {
garply @7; garply @7;
} }
struct TestAllTypes {
voidField @0 : Void;
boolField @1 : Bool;
int8Field @2 : Int8;
int16Field @3 : Int16;
int32Field @4 : Int32;
int64Field @5 : Int64;
uInt8Field @6 : UInt8;
uInt16Field @7 : UInt16;
uInt32Field @8 : UInt32;
uInt64Field @9 : UInt64;
# float32Field @10 : Float32;
# float64Field @11 : Float64;
# ...
}
struct TestOutOfOrder { struct TestOutOfOrder {
foo @3 :Text; foo @3 :Text;
bar @2 :Text; bar @2 :Text;

View file

@ -14,11 +14,12 @@ object Build extends sbt.Build {
project( project(
id = "compiler", id = "compiler",
base = file("compiler") base = file("compiler")
).settings(makeCppTask) ).settings(makeCppTask).dependsOn(runtime)
.settings(compile <<= compile in Compile dependsOn makeCpp) .settings(compile <<= compile in Compile dependsOn makeCpp)
.settings(compileTestSchemaTask) .settings(compileTestSchemaTask)
// .settings(test <<= test in Test dependsOn compileTestSchema)
// .settings(unmanagedSourceDirectories in Test += sourceDirectory.value / "test" / "generated") .settings(test <<= test in Test dependsOn compileTestSchema )
.settings(unmanagedSourceDirectories in Test += sourceDirectory.value / "test" / "generated")
lazy val runtime = lazy val runtime =
project( project(
@ -49,6 +50,7 @@ object Build extends sbt.Build {
val compileTestSchema = taskKey[Unit]("Run capnpc-java on test schema") val compileTestSchema = taskKey[Unit]("Run capnpc-java on test schema")
val compileTestSchemaTask = compileTestSchema := { val compileTestSchemaTask = compileTestSchema := {
val result0 = "mkdir -p compiler/src/test/generated".!!
val result = "capnp compile -I compiler/src/main/cpp/ --src-prefix=compiler/src/test/schema/ -o./capnpc-java:compiler/src/test/generated compiler/src/test/schema/test.capnp".!! val result = "capnp compile -I compiler/src/main/cpp/ --src-prefix=compiler/src/test/schema/ -o./capnpc-java:compiler/src/test/generated compiler/src/test/schema/test.capnp".!!
println(s"**** CodeGen for test.capnp started\n$result\n**** CodeGen complete."); println(s"**** CodeGen for test.capnp started\n$result\n**** CodeGen complete.");
} }

View file

@ -19,13 +19,13 @@ public final class StructBuilder {
this.bit0Offset = bit0Offset; this.bit0Offset = bit0Offset;
} }
public final boolean getBoolField(int offset) { public final boolean getBooleanField(int offset) {
int bitOffset = (offset == 0 ? this.bit0Offset : offset); int bitOffset = (offset == 0 ? this.bit0Offset : offset);
int position = this.data + (bitOffset / 8); int position = this.data + (bitOffset / 8);
return (this.segment.buffer.get(position) & (1 << (bitOffset % 8))) != 0; return (this.segment.buffer.get(position) & (1 << (bitOffset % 8))) != 0;
} }
public final void setBoolField(int offset, boolean value) { public final void setBooleanField(int offset, boolean value) {
int bitOffset = offset; int bitOffset = offset;
if (offset == 0) { bitOffset = this.bit0Offset; } if (offset == 0) { bitOffset = this.bit0Offset; }
byte bitnum = (byte)(bitOffset % 8); byte bitnum = (byte)(bitOffset % 8);

View file

@ -21,7 +21,7 @@ public final class StructReader {
this.nestingLimit = nestingLimit; this.nestingLimit = nestingLimit;
} }
public final boolean getBoolField(int offset) { public final boolean getBooleanField(int offset) {
// XXX should use unsigned operations // XXX should use unsigned operations
if (offset < this.dataSize) { if (offset < this.dataSize) {
if (offset == 0) { if (offset == 0) {

View file

@ -30,27 +30,27 @@ class LayoutSuite extends FunSuite {
// TODO masking // TODO masking
assert(reader.getBoolField(0) === true); assert(reader.getBooleanField(0) === true);
assert(reader.getBoolField(1) === false); assert(reader.getBooleanField(1) === false);
assert(reader.getBoolField(2) === false); assert(reader.getBooleanField(2) === false);
assert(reader.getBoolField(3) === false); assert(reader.getBooleanField(3) === false);
assert(reader.getBoolField(4) === false); assert(reader.getBooleanField(4) === false);
assert(reader.getBoolField(5) === false); assert(reader.getBooleanField(5) === false);
assert(reader.getBoolField(6) === false); assert(reader.getBooleanField(6) === false);
assert(reader.getBoolField(7) == false); assert(reader.getBooleanField(7) == false);
assert(reader.getBoolField(8) === true); assert(reader.getBooleanField(8) === true);
assert(reader.getBoolField(9) === true); assert(reader.getBooleanField(9) === true);
assert(reader.getBoolField(10) === false); assert(reader.getBooleanField(10) === false);
assert(reader.getBoolField(11) === false); assert(reader.getBooleanField(11) === false);
assert(reader.getBoolField(12) === false); assert(reader.getBooleanField(12) === false);
assert(reader.getBoolField(13) === true); assert(reader.getBooleanField(13) === true);
assert(reader.getBoolField(14) === false); assert(reader.getBooleanField(14) === false);
assert(reader.getBoolField(15) === false); assert(reader.getBooleanField(15) === false);
assert(reader.getBoolField(63) === true); assert(reader.getBooleanField(63) === true);
assert(reader.getBoolField(64) === false); assert(reader.getBooleanField(64) === false);
// TODO masking // TODO masking
@ -61,14 +61,14 @@ class LayoutSuite extends FunSuite {
builder.setIntField(2, 0x20212223); builder.setIntField(2, 0x20212223);
builder.setShortField(6, 0x3031.toShort); builder.setShortField(6, 0x3031.toShort);
builder.setByteField(14, 0x40); builder.setByteField(14, 0x40);
builder.setBoolField(120, false); builder.setBooleanField(120, false);
builder.setBoolField(121, false); builder.setBooleanField(121, false);
builder.setBoolField(122, true); builder.setBooleanField(122, true);
builder.setBoolField(123, false); builder.setBooleanField(123, false);
builder.setBoolField(124, true); builder.setBooleanField(124, true);
builder.setBoolField(125, true); builder.setBooleanField(125, true);
builder.setBoolField(126, true); builder.setBooleanField(126, true);
builder.setBoolField(127, false); builder.setBooleanField(127, false);
} }
def checkStruct(builder : StructBuilder) { def checkStruct(builder : StructBuilder) {
@ -76,14 +76,14 @@ class LayoutSuite extends FunSuite {
assert(0x20212223 == builder.getIntField(2)); assert(0x20212223 == builder.getIntField(2));
assert(0x3031 === builder.getShortField(6)); assert(0x3031 === builder.getShortField(6));
assert(0x40 === builder.getByteField(14)); assert(0x40 === builder.getByteField(14));
assert(false === builder.getBoolField(120)); assert(false === builder.getBooleanField(120));
assert(false === builder.getBoolField(121)); assert(false === builder.getBooleanField(121));
assert(true === builder.getBoolField(122)); assert(true === builder.getBooleanField(122));
assert(false === builder.getBoolField(123)); assert(false === builder.getBooleanField(123));
assert(true === builder.getBoolField(124)); assert(true === builder.getBooleanField(124));
assert(true === builder.getBoolField(125)); assert(true === builder.getBooleanField(125));
assert(true === builder.getBoolField(126)); assert(true === builder.getBooleanField(126));
assert(false === builder.getBoolField(127)); assert(false === builder.getBooleanField(127));
} }
test("StructRoundTrip_OneSegment") { test("StructRoundTrip_OneSegment") {