Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Comment: Adding link to Unit Tests page, info I was looking for was there. There seem to be more links to this page, but less info on it. Maybe these two pages should be consolidated as part of cleanup?

...

This

...

page

...

describes

...

how

...

to

...

create

...

unit

...

tests

...

inside

...

of

...

a

...

module.

...

For

...

details

...

on

...

writing

...

unit

...

tests

...

in

...

trunk,

...

see

...

the main Testing page.

Also check out Module Testing against multiple versions of OpenMRS to see how to configure your module poms to allow testing against different versions of OpenMRS core.

Getting Started With Simple Unit Tests

1. Create Your Test

Place a test like this into your /omod/src/test/java/org/openmrs/module/yourmodule

...

folder.package

...

org.openmrs.module.yourmodule;

...

Code Block
/**
* Tests all methods on MyModuleObject
*
*/
public class MyModuleObjectTest {
 


/**

 * Make sure that MyModuleObject runs fine with a null
  * parameter to FeatureX
  *
 
* @throws Exception
  */
  @Test
  public void shouldExamineFeatureXOfMyModuleObject() throws Exception {
   MyModuleObject MyModuleObject obj = new MyModuleObject();
  String  String output = obj.someComplicatedCall("argument1");
   Assert Assert.assertNotNull(output);
  }
}
\[[edit|http://archive.openmrs.org/index.php?title=Module_Unit_Testing&action=edit&section=4]\]

h2. 2. Run the test

(In Eclipse) Right click on your new class and select Run As ? Unit Test\\

\[[edit|http://archive.openmrs.org/index.php?title=Module_Unit_Testing&action=edit&section=5]\]

h1. Getting Started With Service Unit Tests

(or anything using the OpenMRS "Context" object) (or anything using hibernate in your module)

\[[edit|http://archive.openmrs.org/index.php?title=Module_Unit_Testing&action=edit&section=6]\]

h2. 1. Set up your module classpath

You will need to reference most openmrs libraries from your module code (file _/.classpath_). Your classpath will most likely look very similar to this:<?xml version="1.0" encoding="UTF-8"?>
<classpath>
	<classpathentry kind="lib" path="metadata"/>
	<classpathentry kind="src" path="src"/>
	<classpathentry kind="src" path="web/src"/>
	<classpathentry kind="src" path="test"/>
	<classpathentry kind="lib" path="dist"/>
	<classpathentry kind="lib" path="lib-common/activation.jar"/>
	<classpathentry kind="lib" path="lib-common/antlr_2.7.6.jar"/>
	<classpathentry kind="lib" path="lib-common/asm-1.5.3.jar"/>
	<classpathentry kind="lib" path="lib-common/c3p0-0.9.1.jar"/>
	<classpathentry kind="lib" path="lib-common/cglib-2.1_3.jar"/>
	<classpathentry kind="lib" path="lib-common/commons-collections-3.2.jar"/>
	<classpathentry kind="lib" path="lib-common/commons-io-1.4.jar"/>
	<classpathentry kind="lib" path="lib-common/commons-lang-2.4.jar"/>
	<classpathentry kind="lib" path="lib-common/config-1.0.dtd"/>
	<classpathentry kind="lib" path="lib-common/config-1.3.dtd"/>
	<classpathentry kind="lib" path="lib-common/dbunit-2.4.4.jar"/>
	<classpathentry kind="lib" path="lib-common/dom4j-1.6.1.jar"/>
	<classpathentry kind="lib" path="lib-common/dwr-205.jar"/>
	<classpathentry kind="lib" path="lib-common/ehcache-1.2.4.jar"/>
	<classpathentry kind="lib" path="lib-common/hibernate325-mod.jar"/>
	<classpathentry kind="lib" path="lib-common/hsqldb-1.8.0.10.jar"/>
	<classpathentry kind="lib" path="lib-common/jcl-over-slf4j-1.5.6.jar"/>
	<classpathentry kind="lib" path="lib-common/jsp-api.jar"/>
	<classpathentry kind="lib" path="lib-common/jstl-1.1.jar"/>
	<classpathentry kind="lib" path="lib-common/jta.jar"/>
	<classpathentry kind="lib" path="lib-common/junit-4.4.jar"/>
	<classpathentry kind="lib" path="lib-common/liquibase-1.9.4-mod.jar"/>
	<classpathentry kind="lib" path="lib-common/log4j-1.2.15.jar"/>
	<classpathentry kind="lib" path="lib-common/mail.jar"/>
	<classpathentry kind="lib" path="lib-common/openmrs-api-1.6.2.13082-dev.jar"/>
	<classpathentry kind="lib" path="lib-common/resolver.jar"/>
	<classpathentry kind="lib" path="lib-common/servlet-api.jar"/>
	<classpathentry kind="lib" path="lib-common/simple-xml-1.6.1-mod.jar"/>
	<classpathentry kind="lib" path="lib-common/slf4j-api-1.5.6.jar"/>
	<classpathentry kind="lib" path="lib-common/slf4j-log4j12-1.5.6.jar"/>
	<classpathentry kind="lib" path="lib-common/spring-2.5.6.jar"/>
	<classpathentry kind="lib" path="lib-common/spring-test.jar"/>
	<classpathentry kind="lib" path="lib-common/spring-webmvc.jar"/>
	<classpathentry kind="lib" path="lib-common/taglibs-standard-1.1.jar"/>
	<classpathentry kind="lib" path="lib-common/tests-openmrs-api-1.6.2.13082-dev.jar"/>
	<classpathentry kind="lib" path="lib-common/web-openmrs-api-1.6.2.13082-dev.jar"/>
	<classpathentry kind="lib" path="lib-common/xercesImpl.jar"/>
	<classpathentry kind="lib" path="lib-common/xml-apis.jar"/>
	<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER"/>
	<classpathentry kind="lib" path="lib-common/hapi-0.5.jar"/>
	<classpathentry kind="output" path="build"/>
</classpath>
(This is assuming you have checked out [trunk|http://dev.openmrs.org/browser/openmrs/trunk] to the project named "openmrs-trunk")

\[[edit|http://archive.openmrs.org/index.php?title=Module_Unit_Testing&action=edit&section=7]\]

h2. 2. Compile the jar files in trunk

The above classpath assumes that these files exist:
* /openmrs-trunk/dist/openmrs-api-1.4.0.01.5211.jar
* /openmrs-trunk/dist/web-openmrs-api-1.4.0.01.5211.jar
* /openmrs-trunk/dist/tests-openmrs-api-1.4.0.01.5211.jar

They can be compiled with these ant build.xml targets on trunk:
* package-api
* package-web-src
* package-api-tests

And they will be located in the trunk build in the /dist folder.  The  .classpath file in your module refers to these in that location.  You  may need to right click and "refresh" the trunk folders if you're having  problems.

\[[edit|http://archive.openmrs.org/index.php?title=Module_Unit_Testing&action=edit&section=8]\]

h2. 3. Compile Your Module

The .classpath references the /dist folder because it is assuming your compiled .omod file is in there.

Run the ant package-module target to create your module.

\[[edit|http://archive.openmrs.org/index.php?title=Module_Unit_Testing&action=edit&section=9]\]

h2. 4. Create Your Testpackage org.openmrs.module.yourmodule;
 

2. Run the test

(In Eclipse) Right click on your new class and select Run As --> Unit Test

Or at command line:

Code Block
mvn test -Torg.openmrs.mymodule.MyModuleObjectTest

Getting Started With Service Unit Tests

(or anything using the OpenMRS "Context" object) (or anything using hibernate in your module)

Check your pom.xml files

If you use the Maven archetype to create your module, see this. If you are using an older mavenized or unmavenized module, see this.

Put these into your main pom.xml (in Eclipse, open the pom choose the Dependencies tab and add a new one below those that exist):

Code Block
<dependency>
    <groupId>org.openmrs.test</groupId>
    <artifactId>openmrs-test</artifactId>
    <version>${openMRSVersion}</version>
    <type>pom</type>
    <scope>test</scope>
</dependency>

and into your api and omod poms

Code Block
<dependency>
    <groupId>org.openmrs.api</groupId>
    <artifactId>openmrs-api</artifactId>
    <version>${openMRSVersion}</version>
    <type>test-jar</type>
    <scope>test</scope>
</dependency>

The two dependencies should be placed in the modue (api/omod) pom files for openmrs platform 1.11.x, may not need to update the parent pom file


Create Your Test

Code Block
package org.openmrs.module.yourmodule;
/**
* Tests the MyModuleService class and all of its methods
*
**/
public class MyModuleServiceTest extends BaseModuleContextSensitiveTest {
 


/**
 
* Make sure that MyService runs fine with a null

 * parameter to getMyModuleObject
  *
 
* @throws Exception
 
*/
  @Test
 
public void shouldGetMyModuleObjectWithNullParameter() throws Exception {
      MyModuleService service = ((MyModuleService)Context.getService(MyModuleService.class));
     MyModuleObject obj = service.getMyModuleByName(null);
     Assert.assertNull(output);
  }
}
\[[edit|http://archive.openmrs.org/index.php?title=Module_Unit_Testing&action=edit&section=10]\]

h2. 5. Run Your Test

(In Eclipse) Right click on your new class and select Run As ? Unit Test

(The BaseModuleContextSensitiveTest class will run through the  Spring setup, loads in any omods on the classpath, creates the Context  and ServiceContext classes required by the OpenMRS API.  This startup  takes a few seconds, so when you can, create simple tests that don't  need Context and don't extend BaseModuleContextSensistiveTest)\\

\[[edit|http://archive.openmrs.org/index.php?title=Module_Unit_Testing&action=edit&section=11]\]

h1. Logging in JUnit Module Tests

# You must have log4j referenced explicitly in your .classpath file
# log4j.xml's parent folder must be in your classpath in order to be found by log4j (like in /metadata or /dist)
#* The log4j.xml can will look something like:

Run Your Test

(In Eclipse) Right click on your new class and select Run As --> Unit Test

(The BaseModuleContextSensitiveTest class will run through the Spring setup, loads in any omods on the classpath, creates the Context and ServiceContext classes required by the OpenMRS API. This startup takes a few seconds, so when you can, create simple tests that don't need Context and don't extend BaseModuleContextSensistiveTest)

Logging in JUnit Module Tests

This information is intended for older mavenized or unmavenized modules, it has not been verified using the Maven archetype

  • You must have log4j referenced explicitly in your .classpath file
  • log4j.xml's parent folder must be in your classpath in order to be found by log4j (like in /metadata or /dist)
  • The log4j.xml will look something like:

    Code Block
    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
    

...

  • 
    <log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
    

...

  • 
    

...

  • <appender name="CONSOLE" class="org.apache.log4j.ConsoleAppender">
    

...

  • <layout class="org.apache.log4j.PatternLayout">
    

...

  • <param name="ConversionPattern"
    

...

  • value="%p - %C{1}.%M(%L) |%d{ISO8601}| %m%n" />
    

...

  • </layout>
    

...

  • </appender>

...

  • 
    
    

...

  • <logger name="org.openmrs.module.remoteformentry">
    

...

  • <level value="DEBUG" />

...

  • 
    

...

  • </

...

  • logger> 
    

...

  • 
    

...

  • <root>
    

...

  • <level value="ERROR" />
    

...

  • <appender-ref ref="CONSOLE" />
    

...

  • </root>
    

...

  • 
    </log4j:configuration>
    

...


Including Other Required Modules in JUnit Tests

  • For modules using the Maven archetype, you will need to do a clean install on your dependent modules.
  • For older mavenized or unmavenized modules, package the required module into its omod file and drop it into the /lib-common folder

Extras

  • If you've added a log4j.xml file to your metadata directory and metadata is referenced in the .classpath file and you still don't see any log messages in the console during the execution of the test, make sure that the metadata directory comes before all JARs that might have a log4j.xml in them already (i.e. openmrs-api.jar)
  • If you create custom tables and map them using hibernate, an error in the <table_name>.hbm.xml

...

  • can

...

  • be

...

  • masked

...

  • and

...

  • you

...

  • will

...

  • just

...

  • get

...

  • an

...

  • error

...

  • to

...

  • the

...

  • effect

...

  • that

...

  • your

...

  • service

...

  • cannot

...

  • be

...

  • found

...

  • when

...

  • you

...

  • call

...

  • Context.getService(<your_service>.class).

...

  • If

...

  • you

...

  • compile

...

  • the

...

  • module

...

  • and

...

  • load

...

  • it

...

  • into

...

  • the

...

  • OpenMRS

...

  • web

...

  • interface,

...

  • it

...

  • will

...

  • tell

...

  • you

...

  • the

...

  • real

...

  • error.

...

  • If

...

  • you

...

  • get

...

  • an

...

  • exception

...

  • like

...

  • org.openmrs.api.APIException:

...

  • Service

...

  • not

...

  • found:

...

  • class

...

  • org.openmrs.module.

...

  • ...

...

  • then

...

  • you

...

  • may

...

  • need

...

  • to

...

  • do

...

  • one

...

  • of

...

  • two

...

  • things.

...

  • First,

...

  • make

...

  • sure

...

  • that

...

  • you

...

  • have

...

  • run

...

  • the

...

  • ant "package

...

  • module"

...

  • task.

...

  • If

...

  • you've

...

  • already

...

  • done

...

  • that,

...

  • then

...

  • you

...

  • probably

...

  • need

...

  • to

...

  • fix

...

  • your

...

  • build

...

  • file

...

  • for

...

  • the

...

  • module

...

  • you're

...

  • including.

...

    1. Open

...

    1. build.xml

...

    1. in

...

    1. the

...

    1. module

...

    1. you're

...

    1. compiling

...

    1. Find

...

    1. the

...

    1. "package-jar"

...

    1. target

...

    1. Remove

...

    1. the

...

    1. line

...

    1. like

...

    1. "<exclude

...

    1. name="*"

...

    1. />"

...

    1. Repackage

...

    1. your

...

    1. jar

...

    1. file

...

    1. and

...

    1. try

...

    1. using

...

    1. it

...

    1. again

...

    1. in

...

    1. the

...

    1. other

...

    1. module

...

  • To

...

  • skip

...

  • the

...

  • authentication

...

  • username/popup

...

  • when

...

  • testing,

...

  • place

...

  • these

...

  • variables

...

  • into

...

  • your

...

  • runtime

...

  • properties

...

  • file:

...

  • junit.username=admin

...


  • junit.password=test

...

Troubleshooting

org.dbunit.dataset.NoSuchTableException:

...

(my_table_name)

You

...

need

...

to

...

make

...

sure

...

that

...

(1)

...

you

...

have

...

built

...

an

...

omod

...

for

...

your

...

module,

...

(2)

...

thedistfolder

...

is

...

in

...

your

...

classpath,

...

e.g.

...

by

...

adding

...

this

...

line

...

to

...

your.classpathfile:<classpathentry

...

kind="lib"

...

path="dist"/>.

...

You

...

may

...

also

...

need

...

to

...

refresh

...

your

...

eclipse

...

Package

...

Explorer

...

or

...

Navigator

...

so

...

it

...

knows

...

about

...

the dist folder.

org.openmrs.api.APIException:

...

Service

...

not

...

found:

...

class

...

org.openmrs.module.

First,

...

make

...

sure

...

that

...

you

...

have

...

run the package module Ant target.

...

Secondly,

...

make

...

sure

...

your

...

test

...

class

...

extendsBaseModuleContextSensitiveTest. Second,

...

make

...

sure

...

your

...

"build"

...

folder

...

was

...

on

...

the

...

.classpath

...

so

...

that

...

Eclipse

...

knows

...

about

...

your

...

compiled

...

classes

org.hibernate.MappingException:

...

Unknown

...

entity:

...

org.openmrs.module.<module>.

...

<Object>

Hibernate will

...

only

...

look

...

for

...

your

...

module's

...

Hibernate

...

mapping

...

files

...

(

...

.hbm.xml)

...

in classpath:*.omod.

...

You

...

must

...

have

...

the

...

reference

...

to <classpathentry kind="lib"

...

path="dist"/

...

> in your

...

module's .classpathfile

...

(see

...

above).

...

NOTE: Since

...

/dist

...

is

...

now

...

a

...

referenced

...

library,

...

you

...

might

...

also

...

need

...

to

...

make

...

sure

...

it

...

is

...

present

...

at

...

compilation

...

time

...

(Ant-clean

...

deletes

...

it).

...

Rearrange

...

your

...

build.xml

...

to

...

create

...

/dist

...

before

...

the

...

compilation

...

call.

...

You

...

may

...

need

...

to

...

do

...

an

...

Eclipse

...

clean

...

(which

...

is

...

different

...

than

...

an

...

Ant

...

clean)

...

and

...

then

...

repeat

...

this

...

step.

...

org.springframework.beans.factory.UnsatisfiedDependencyException:

...

Error

...

creating

...

bean

...

with

...

name

...

'<JUnit

...

Test

...

Class>':

...

Unsatisfied

...

dependency

...

expressed

...

through

...

bean

...

property

...

'transactionManager':

...

Set

...

this

...

property

...

value

...

or

...

disable

...

dependency

...

checking

...

for

...

this

...

bean.

(When

...

running

...

unit

...

tests

...

in

...

Eclipse) Make

...

sure

...

that

...

you

...

are

...

using Spring 2.

...

5 or above.

...

You

...

can

...

also

...

addsetDependencyCheck(false) to

...

the

...

constructor

...

of

...

your

...

test

...

class.

Related Links

Unit Tests