From 1b9044499498acfd0f472a5a8ae353665a0fcd10 Mon Sep 17 00:00:00 2001 From: =?utf8?q?David=20=E2=80=98Bombe=E2=80=99=20Roden?= Date: Wed, 13 Nov 2013 22:15:54 +0100 Subject: [PATCH] Add unit test for SimpleFieldSetBuilder. --- .../sone/freenet/SimpleFieldSetBuilderTest.java | 73 ++++++++++++++++++++++ 1 file changed, 73 insertions(+) create mode 100644 src/test/java/net/pterodactylus/sone/freenet/SimpleFieldSetBuilderTest.java diff --git a/src/test/java/net/pterodactylus/sone/freenet/SimpleFieldSetBuilderTest.java b/src/test/java/net/pterodactylus/sone/freenet/SimpleFieldSetBuilderTest.java new file mode 100644 index 0000000..9b2cf38 --- /dev/null +++ b/src/test/java/net/pterodactylus/sone/freenet/SimpleFieldSetBuilderTest.java @@ -0,0 +1,73 @@ +/* + * Sone - SimpleFieldSetBuilderTest.java - Copyright © 2013 David Roden + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . + */ + +package net.pterodactylus.sone.freenet; + +import static net.pterodactylus.sone.Matchers.contains; +import static net.pterodactylus.sone.Matchers.containsInAnyOrder; +import static org.hamcrest.MatcherAssert.assertThat; +import static org.hamcrest.Matchers.is; + +import freenet.node.FSParseException; +import freenet.support.SimpleFieldSet; + +import org.junit.Test; + +/** + * Unit test for {@link SimpleFieldSetBuilder}. + * + * @author David ‘Bombe’ Roden + */ +public class SimpleFieldSetBuilderTest { + + private final SimpleFieldSetBuilder simpleFieldSetBuilder = new SimpleFieldSetBuilder(); + + @Test + public void creatingASimpleFieldSetWithAStringValue() { + SimpleFieldSet fieldSet = simpleFieldSetBuilder.put("Key", "Value").get(); + assertThat(fieldSet.keyIterator(), contains("Key")); + assertThat(fieldSet.get("Key"), is("Value")); + } + + @Test + public void creatingASimpleFieldSetWithAnIntValue() throws FSParseException { + SimpleFieldSet fieldSet = simpleFieldSetBuilder.put("Key", 17).get(); + assertThat(fieldSet.keyIterator(), contains("Key")); + assertThat(fieldSet.getInt("Key"), is(17)); + } + + @Test + public void creatingASimpleFieldSetWithALongValue() throws FSParseException { + SimpleFieldSet fieldSet = simpleFieldSetBuilder.put("Key", 17L).get(); + assertThat(fieldSet.keyIterator(), contains("Key")); + assertThat(fieldSet.getLong("Key"), is(17L)); + } + + @Test + public void creatingASimpleFieldSetWithAnotherFieldSet() throws FSParseException { + SimpleFieldSet originalFieldSet = new SimpleFieldSet(true); + originalFieldSet.putSingle("StringKey", "Value"); + originalFieldSet.put("IntKey", 17); + originalFieldSet.put("LongKey", 17L); + SimpleFieldSet fieldSet = simpleFieldSetBuilder.put(originalFieldSet).get(); + assertThat(fieldSet.keyIterator(), containsInAnyOrder("IntKey", "StringKey", "LongKey")); + assertThat(fieldSet.get("StringKey"), is("Value")); + assertThat(fieldSet.getInt("IntKey"), is(17)); + assertThat(fieldSet.getLong("LongKey"), is(17L)); + } + +} -- 2.7.4