All Downloads are FREE. Search and download functionalities are using the official Maven repository.

jars.nosqlunit-documentation.0.10.0.source-code.couchdb.xml Maven / Gradle / Ivy

There is a newer version: 1.0.0
Show newest version
<?xml version="1.0" encoding="UTF-8"?>
<chapter version="5.0" xml:id="couchdb" xmlns="http://docbook.org/ns/docbook"
	xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:xi="http://www.w3.org/2001/XInclude"
	xmlns:svg="http://www.w3.org/2000/svg" xmlns:m="http://www.w3.org/1998/Math/MathML"
	xmlns:html="http://www.w3.org/1999/xhtml" xmlns:db="http://docbook.org/ns/docbook">
    
    <title>CouchDB Engine</title>
	
	<section>
		<title>CouchDB</title>

		<para>
			<application>CouchDB</application>
			is a
			<emphasis>NoSQL</emphasis>
			database that stores structured data as
			<emphasis>JSON-like</emphasis>
			documents with dynamic schemas.
		</para>

		<para>
			<emphasis role="bold">NoSQLUnit</emphasis>
			supports
			<emphasis>CouchDB</emphasis>
			by using next classes:
		</para>
		<para>
		<table border="1">
			<caption>Lifecycle Management Rules</caption>
			<tr>
				<td>Managed</td>

				<td>
					<classname>com.lordofthejars.nosqlunit.couchdb.ManagedCouchDb
					</classname>
				</td>
			</tr>
		</table>
		</para>
		<para>
		<table border="1">
			<caption>Manager Rule</caption>

			<tr>
				<td>NoSQLUnit Management</td>

				<td>
					<classname>com.lordofthejars.nosqlunit.couchdb.CouchDbRule
					</classname>
				</td>
			</tr>
		</table>
		</para>
		<section>
			<title>Maven Setup</title>

			<para>
				To use
				<emphasis role="bold">NoSQLUnit</emphasis>
				with
				<application>CouchDB</application>
				you only need to add next
				dependency:
			</para>

			<example xml:id="conf.couchdb_nosqlunit_dep">
				<title>NoSqlUnit Maven Repository</title>

				<programlisting language="xml"><![CDATA[<dependency>
	<groupId>com.lordofthejars</groupId>
	<artifactId>nosqlunit-couchdb</artifactId>
	<version>${version.nosqlunit}</version>
</dependency>]]></programlisting>
			</example>
		</section>

		<section>
			<title>Dataset Format</title>

			<para>
				Default dataset file format in
				<emphasis>CouchDB</emphasis>
				module
				is
				<emphasis>json</emphasis>
				.
			</para>

			<para>
				Datasets must have next
				<link linkend="ex.couchdb_dataset">
					format
				</link>
				:
			</para>

			<example xml:id="ex.couchdb_dataset">
				<title>Example of CouchDB Dataset</title>

				<programlisting language="json"><![CDATA[{
	"data":
			[
				{"attribute1":"value1", "atribute2":"value2", ...},
				{...}
			]
}]]></programlisting>
			</example>

			<para>Notice that if attributes value are integers, double quotes are
				not required.
			</para>
		</section>

		<section>
			<title>Getting Started</title>

			<section>
				<title>Lifecycle Management Strategy</title>

				<para>
					First step is defining which lifecycle management strategy is
					required for your tests. Depending on kind of test you are
					implementing (unit test, integration test, deployment test, ...)
					you
					will require an
					<emphasis role="bold">managed</emphasis>
					approach or
					<emphasis role="bold">remote</emphasis>
					approach.
				</para>

				<para>
				There is no <emphasis>CouchDB</emphasis> inmemory instance, so only managed or remote lifecycle can be used.
				</para>

				<para>
					To configure the
					<emphasis role="bold">managed</emphasis>
					way,
					you should use
					<classname>ManagedCouchDb</classname>
					rule and may
					require some <link linkend="program.couchdb_managed_conf">configuration</link> parameters.
				</para>

				<example xml:id="program.couchdb_managed_conf">
					<title>Managed CouchDB</title>

					<programlisting language="java"><![CDATA[import static com.lordofthejars.nosqlunit.couchdb.ManagedCouchDb.ManagedCouchDbRuleBuilder.newManagedCouchDbRule;

@ClassRule
public static ManagedCouchDb managedCouchDb = newManagedCouchDbRule().couchDbPath("/usr/local").build(); ]]></programlisting>
				</example>

				<para>
					By default managed
					<emphasis>CouchDB</emphasis>
					rule uses next
					default values:
				</para>

				<itemizedlist>
					<listitem>
						<para>
							<emphasis>CouchDB</emphasis>
							installation directory is
							retrieved from
							<varname>COUCHDB_HOME</varname>
							system environment
							variable.
						</para>
					</listitem>

					<listitem>
						<para>
							Target path, that is the directory where
							<emphasis>CouchDB</emphasis>
							server is started, is
							<constant>target/couchdb-temp</constant>
							.
						</para>
					</listitem>
					
					<listitem>
						<para>
							Port where <emphasis>CouchDB</emphasis> will be started. Note that this parameter is used only as information, if you change port from configuration file you should change this parameter too.
							By default<emphasis>CouchDB</emphasis>
							server is started at
							<constant>5984</constant>
							.
						</para>
					</listitem>

				</itemizedlist>

								<para>
					Configuring
					<emphasis role="bold">remote</emphasis>
					approach
					does not require any special rule because you (or System like
					<application>Maven</application>
					) is the responsible of starting and
					stopping the server. This mode is used in deployment tests where you
					are testing your application on real environment.
				</para>
			</section>

			<section>
				<title>Configuring CouchDB Connection</title>

				<para>
					Next step is configuring
					<emphasis>
						<emphasis role="bold">CouchDB</emphasis>
					</emphasis>
					rule in charge of
					maintaining
					<emphasis>CouchDB</emphasis>
					database into known state by
					inserting and deleting defined datasets. You must register
					<classname>CouchDbRule</classname>
					<emphasis>JUnit</emphasis>
					rule
					class, which requires a configuration parameter with information like
					host, port or database name.
				</para>

				<para>To make developer's life easier and code more readable, a
					fluent
					interface can be used to create these configuration objects.
				</para>

				<table border="1">
					<caption>Default Managed Configuration Values</caption>

					<tr>
						<td>URI</td>

						<td>http://localhost5984</td>
					</tr>
					<tr>
						<td>Authentication</td>

						<td>No authentication parameters.</td>
					</tr>
					<tr>
						<td>Enable SSL</td>

						<td>false.</td>
					</tr>
					<tr>
						<td>Relaxed SSL Settings</td>

						<td>false.</td>
					</tr>
					<tr>
						<td>Caching</td>

						<td>True.</td>
					</tr>
				</table>

				<example xml:id="program.couchdb_managed_connection_parameters">
					<title>CouchDBRule with managed configuration</title>

					<programlisting language="java"><![CDATA[import static com.lordofthejars.nosqlunit.couchdb.CouchDbRule.CouchDbRuleBuilder.newCouchDbRule;

@Rule
public CouchDbRule couchDbRule = newCouchDbRule().defaultManagedMongoDb("books");]]></programlisting>
				</example>

			</section>

			<section>
				<title>Complete Example</title>

				<para>
					Consider a library application, which apart from multiple
					operations, it allow us to add new books to system. Our
					<link linkend="example.couchdb_book_model">model</link>
					is as simple as:
				</para>

				<example xml:id="example.couchdb_book_model">
					<title>Book POJO</title>

					<programlisting language="java"><![CDATA[public class Book {

	private String title;

	private int numberOfPages;

	public Book(String title, int numberOfPages) {
		super();
		this.title = title;
		this.numberOfPages = numberOfPages;
	}

	public void setTitle(String title) {
		this.title = title;
	}

	public void setNumberOfPages(int numberOfPages) {
		this.numberOfPages = numberOfPages;
	}


	public String getTitle() {
		return title;
	}

	public int getNumberOfPages() {
		return numberOfPages;
	}
}]]></programlisting>
				</example>

				<para>
					Next business
					<link linkend="example.couchdb_book_manager">class</link>
					is the responsible of managing access to
					<emphasis>CouchDB</emphasis>
					server:
				</para>

				<example xml:id="example.couchdb_book_manager">
					<title>Book POJO</title>

					<programlisting language="java"><![CDATA[private CouchDbConnector connector;
	
	public BookManager(CouchDbConnector connector)  {
		this.connector = connector;
	}
	
	public void create(Book book) {
		connector.create(MapBookConverter.toMap(book));
	}

	public Book findBookById(String id) {
		Map<String, Object> map = connector.get(Map.class, id);
		return MapBookConverter.toBook(map);
	}]]></programlisting>
				</example>

				<para>
					And now it is time for testing. In next
					<link linkend="example.couchdb_test_find_book">test</link>
					we are going to
					validate that a book is found into database.
				</para>

				<example xml:id="example.couchdb_test_find_book">
					<title>Test with Managed Connection</title>

					<programlisting language="java"><![CDATA[public class WhenYouFindBooksById {

	@ClassRule
	public static ManagedCouchDb managedCouchDb = newManagedCouchDbRule().couchDbPath("/usr/local").build(); 
	
	@Rule
	public CouchDbRule couchDbRule = newCouchDbRule().defaultManagedMongoDb("books");
	
	@Inject
	private CouchDbConnector couchDbConnector;
	
	@Test
	@UsingDataSet(locations="books.json", loadStrategy=LoadStrategyEnum.CLEAN_INSERT)
	public void identified_book_should_be_returned() {
		
		BookManager bookManager = new BookManager(couchDbConnector);
		Book book = bookManager.findBookById("1");
		
		assertThat(book.getTitle(), is("The Hobbit"));
		assertThat(book.getNumberOfPages(), is(293));
		
	}
	
}]]></programlisting>
				</example>

				<example xml:id="example.couchdb_dataset_book">
					<title>Initial Dataset</title>

					<programlisting language="json"><![CDATA[{
	"data":
			[
				{"_id":"1", "title":"The Hobbit","numberOfPages":"293"}
			]
}]]></programlisting>
				</example>

				<para>
					You can watch full example at
					<link
						xlink:href="https://github.com/lordofthejars/nosql-unit/tree/master/nosqlunit-demo">github</link>
					.
				</para>
			</section>
		</section>
	</section>

</chapter>




© 2015 - 2025 Weber Informatics LLC | Privacy Policy