
<!DOCTYPE html
  PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
   <head>
      <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
   
      <!--
This HTML is auto-generated from an M-file.
To make changes, update the M-file and republish this document.
      -->
      <title>How to Write xUnit-Style Tests by Subclassing TestCase</title>
      <meta name="generator" content="MATLAB 7.8">
      <meta name="date" content="2009-06-05">
      <meta name="m-file" content="exTestCase"><style type="text/css">

body {
  background-color: white;
  margin:10px;
}

h1 {
  color: #990000; 
  font-size: x-large;
}

h2 {
  color: #990000;
  font-size: medium;
}

/* Make the text shrink to fit narrow windows, but not stretch too far in 
wide windows. */ 
p,h1,h2,div.content div {
  max-width: 600px;
  /* Hack for IE6 */
  width: auto !important; width: 600px;
}

pre.codeinput {
  background: #EEEEEE;
  padding: 10px;
}
@media print {
  pre.codeinput {word-wrap:break-word; width:100%;}
} 

span.keyword {color: #0000FF}
span.comment {color: #228B22}
span.string {color: #A020F0}
span.untermstring {color: #B20000}
span.syscmd {color: #B28C00}

pre.codeoutput {
  color: #666666;
  padding: 10px;
}

pre.error {
  color: red;
}

p.footer {
  text-align: right;
  font-size: xx-small;
  font-weight: lighter;
  font-style: italic;
  color: gray;
}

  </style></head>
   <body>
      <div class="content">
         <h1>How to Write xUnit-Style Tests by Subclassing TestCase</h1>
         <p>The MATLAB xUnit architecture is based closely on the xUnit style, in which each test case is an instance of a subclass of
            the base TestCase class.  Programmers who are familiar with this style may want to write their own TestCase subclasses instead
            of using <a href="./exSubfunctionTests.html">subfunction-based tests</a>.
         </p>
         <p>This example shows a TestCase subclass containing test case methods and test fixture methods.  If you are not familiar with
            defining your own classes in MATLAB, you might want to review the MATLAB documentation on <a href="http://www.mathworks.com/access/helpdesk/help/techdoc/matlab_oop/ug_intropage.html">classes and object-oriented programming</a>, or you can simply stick to using subfunction-based tests.
         </p>
         <p>The sample M-file begins with the <tt>classdef</tt> statement, which sets the name of the class and indicates that it is a subclass of <tt>TestCase</tt>.
         </p><pre class="codeinput">cd <span class="string">examples_general</span>
dbtype <span class="string">TestUsingTestCase</span> <span class="string">1</span>
</pre><pre class="codeoutput">
1     classdef TestUsingTestCase &lt; TestCase

</pre><p>The properties block contains a field that is initialized by the setup method and is used by the two test methods.</p><pre class="codeinput">dbtype <span class="string">TestUsingTestCase</span> <span class="string">3:5</span>
</pre><pre class="codeoutput">
3         properties
4             fh
5         end

</pre><p>The first method in the methods block is the constructor.  It takes the desired test method name as its input argument, and
            it passes that input along to the base class constructor.
         </p><pre class="codeinput">dbtype <span class="string">TestUsingTestCase</span> <span class="string">7:10</span>
</pre><pre class="codeoutput">
7         methods
8             function self = TestUsingTestCase(name)
9                 self = self@TestCase(name);
10            end

</pre><p>The <tt>setUp</tt> method creates a figure window and stores its handle in the field <tt>fh</tt>.
         </p><pre class="codeinput">dbtype <span class="string">TestUsingTestCase</span> <span class="string">12:14</span>
</pre><pre class="codeoutput">
12            function setUp(self)
13                self.fh = figure;
14            end

</pre><p>Test methods are those beginning with "test".</p><pre class="codeinput">dbtype <span class="string">TestUsingTestCase</span> <span class="string">20:26</span>
</pre><pre class="codeoutput">
20            function testColormapColumns(self)
21                assertEqual(size(get(self.fh, 'Colormap'), 2), 3);
22            end
23    
24            function testPointer(self)
25                assertEqual(get(self.fh, 'Pointer'), 'arrow');
26            end

</pre><p>The <tt>tearDown</tt> method cleans up by deleting the figure window.
         </p><pre class="codeinput">dbtype <span class="string">TestUsingTestCase</span> <span class="string">16:18</span>
</pre><pre class="codeoutput">
16            function tearDown(self)
17                delete(self.fh);
18            end

</pre><p>Run the test cases in the class by calling <tt>runtests</tt> with the name of the class.
         </p><pre class="codeinput">runtests <span class="string">TestUsingTestCase</span>
</pre><pre class="codeoutput">Starting test run with 2 test cases.
..
PASSED in 0.246 seconds.
</pre><p class="footer">Copyright 2008-2009 The MathWorks, Inc.<br>
            Published with MATLAB&reg; 7.8<br></p>
      </div>
      <!--
##### SOURCE BEGIN #####
%% How to Write xUnit-Style Tests by Subclassing TestCase
% The MATLAB xUnit architecture is based closely on the xUnit style, in
% which each test case is an instance of a subclass of the base
% TestCase class.  Programmers who are familiar with this style may
% want to write their own TestCase subclasses instead of using
% <./exSubfunctionTests.html subfunction-based tests>.
%
% This example shows a TestCase subclass containing test case
% methods and test fixture methods.  If you are not familiar with
% defining your own classes in MATLAB, you might want to review the
% MATLAB documentation on 
% <http://www.mathworks.com/access/helpdesk/help/techdoc/matlab_oop/ug_intropage.html 
% classes and object-oriented programming>,
% or you can simply stick to using subfunction-based tests.
%
% The sample M-file begins with the |classdef| statement, which sets
% the name of the class and indicates that it is a subclass of
% |TestCase|.

cd examples_general
dbtype TestUsingTestCase 1

%%
% The properties block contains a field that is initialized by the
% setup method and is used by the two test methods.

dbtype TestUsingTestCase 3:5

%%
% The first method in the methods block is the constructor.  It
% takes the desired test method name as its input argument, and it
% passes that input along to the base class constructor.

dbtype TestUsingTestCase 7:10

%%
% The |setUp| method creates a figure window and stores its handle in
% the field |fh|.

dbtype TestUsingTestCase 12:14

%%
% Test methods are those beginning with "test".

dbtype TestUsingTestCase 20:26

%%
% The |tearDown| method cleans up by deleting the figure window.

dbtype TestUsingTestCase 16:18

%%
% Run the test cases in the class by calling |runtests| with the name
% of the class.

runtests TestUsingTestCase

%%
% Copyright 2008-2009 The MathWorks, Inc.
##### SOURCE END #####
-->
   </body>
</html>