Formatting cleanup

pull/555/head
danroth27 2015-11-17 22:13:29 -08:00
parent d1603d670a
commit af4c88e396
1 changed files with 42 additions and 49 deletions

View File

@ -4,16 +4,16 @@ By `Steve Smith`_
ASP.NET 5 has been designed with testability in mind, so that creating unit tests for your applications is easier than ever before. This article briefly introduces unit tests (and how they differ from other kinds of tests) and demonstrates how to add a test project to your solution and then run unit tests using either the command line or Visual Studio. ASP.NET 5 has been designed with testability in mind, so that creating unit tests for your applications is easier than ever before. This article briefly introduces unit tests (and how they differ from other kinds of tests) and demonstrates how to add a test project to your solution and then run unit tests using either the command line or Visual Studio.
In this article: .. contents:: In this article:
- `Getting Started with Testing`_ :local:
- `Creating Test Projects`_ :depth: 1
- `Running Tests`_
`Download sample from GitHub <https://github.com/aspnet/docs/tree/1.0.0-beta8/aspnet/testing/unit-testing/sample>`_. `Download sample from GitHub <https://github.com/aspnet/docs/tree/1.0.0-beta8/aspnet/testing/unit-testing/sample>`_.
Getting Started with Testing Getting Started with Testing
---------------------------- ----------------------------
Having a suite of automated tests is one of the best ways to ensure a software application does what its authors intended it to do. There are many different kinds of tests for software applications, including :doc:`integration tests <integration-testing>`, web tests, load tests, and many others. At the lowest level are unit tests, which test individual software components or methods. Unit tests should only test code within the developer's control, and should not test infrastructure concerns, like databases, file systems, or network resources. Unit tests may be written using `Test Driven Development(TDD) <http://deviq.com/test-driven-development/>`_, or they can be added to existing code to confirm its correctness. In either case, they should be small, well-named, and fast, since ideally you will want to be able to run hundreds of them before pushing your changes into the project's shared code repository.
Having a suite of automated tests is one of the best ways to ensure a software application does what its authors intended it to do. There are many different kinds of tests for software applications, including :doc:`integration tests <integration-testing>`, web tests, load tests, and many others. At the lowest level are unit tests, which test individual software components or methods. Unit tests should only test code within the developer's control, and should not test infrastructure concerns, like databases, file systems, or network resources. Unit tests may be written using `Test Driven Development (TDD) <http://deviq.com/test-driven-development/>`_, or they can be added to existing code to confirm its correctness. In either case, they should be small, well-named, and fast, since ideally you will want to be able to run hundreds of them before pushing your changes into the project's shared code repository.
.. note:: Developers often struggle with coming up with good names for their test classes and methods. As a starting point, the ASP.NET product team follows `these conventions <https://github.com/aspnet/Home/wiki/Engineering-guidelines#unit-tests-and-functional-tests>`_ .. note:: Developers often struggle with coming up with good names for their test classes and methods. As a starting point, the ASP.NET product team follows `these conventions <https://github.com/aspnet/Home/wiki/Engineering-guidelines#unit-tests-and-functional-tests>`_
@ -21,59 +21,60 @@ When writing unit tests, be careful you don't accidentally introduce dependencie
Creating Test Projects Creating Test Projects
---------------------- ----------------------
A test project is just a class library with references to a test runner and the project being tested (also referred to as the System Under Test or SUT). It's a good idea to organize your test projects in a separate folder from your SUT projects, and the recommended convention for DNX projects is something like this:
.. code-block:: text A test project is just a class library with references to a test runner and the project being tested (also referred to as the System Under Test or SUT). It's a good idea to organize your test projects in a separate folder from your SUT projects, and the recommended convention for DNX projects is something like this::
global.json
PrimeWeb.sln
src/
PrimeWeb/
project.json
Startup.cs
Services/
PrimeService.cs
test/
PrimeWeb.UnitTests/
project.json
Services/
PrimeService_IsPrimeShould.cs
global.json
PrimeWeb.sln
src/
PrimeWeb/
project.json
Startup.cs
Services/
PrimeService.cs
test/
PrimeWeb.UnitTests/
project.json
Services/
PrimeService_IsPrimeShould.cs
It is important that there be a folder/directory with the name of the project you are testing (PrimeWeb above), since the file system is used to find your project. It is important that there be a folder/directory with the name of the project you are testing (PrimeWeb above), since the file system is used to find your project.
Configuring the Test project.json Configuring the Test project.json
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
The test project's ``project.json`` file should add dependencies on the test framework being used and the SUT project. For example, to work with the `xUnit test framework <http://xunit.github.io/>`_, you would configure the dependencies as follows: The test project's ``project.json`` file should add dependencies on the test framework being used and the SUT project. For example, to work with the `xUnit test framework <http://xunit.github.io/>`_, you would configure the dependencies as follows:
.. literalinclude:: unit-testing/sample/test/PrimeWeb.UnitTests/project.json .. literalinclude:: unit-testing/sample/test/PrimeWeb.UnitTests/project.json
:language: javascript :language: json
:lines: 20-24 :lines: 20-24
:linenos: :linenos:
:dedent: 2 :dedent: 2
As other test frameworks release support for DNX, we will link to them here. We are simply using xUnit as one example of the many different testing frameworks that can be plugged into ASP.NET and DNX. As other test frameworks release support for DNX, we will link to them here. We are simply using xUnit as one example of the many different testing frameworks that can be plugged into ASP.NET and DNX.
.. note:: Be sure the version numbers match for your project-to-project references. .. note:: Be sure the version numbers match for your project-to-project references.
In addition to adding dependencies, we also want to be able to run the tests using a dnx command. To do so, add the following commands section to ``project.json``: In addition to adding dependencies, we also want to be able to run the tests using a DNX command. To do so, add the following commands section to ``project.json``:
.. literalinclude:: unit-testing/sample/test/PrimeWeb.UnitTests/project.json .. literalinclude:: unit-testing/sample/test/PrimeWeb.UnitTests/project.json
:language: javascript :language: json
:lines: 25-27 :lines: 25-27
:linenos: :linenos:
:dedent: 2 :dedent: 2
.. note:: Learn more about :doc:`/dnx/commands` in DNX. .. note:: Learn more about :doc:`/dnx/commands` in DNX.
Running Tests Running Tests
------------- -------------
Before you can run your tests, you'll need to write some. For this demo, I've created a simple service that checks whether numbers are prime. One of the tests is shown here: Before you can run your tests, you'll need to write some. For this demo, I've created a simple service that checks whether numbers are prime. One of the tests is shown here:
.. literalinclude:: unit-testing/sample/test/PrimeWeb.UnitTests/Services/PrimeService_IsPrimeShould.cs .. literalinclude:: unit-testing/sample/test/PrimeWeb.UnitTests/Services/PrimeService_IsPrimeShould.cs
:language: c# :language: c#
:lines: 18-27 :lines: 18-27
:linenos: :linenos:
:dedent: 8 :dedent: 8
This test will check the values -1, 0, and 1 using the ``IsPrime`` method in each of three separate tests. Each test will pass if ``IsPrime`` returns false, and will otherwise fail. This test will check the values -1, 0, and 1 using the ``IsPrime`` method in each of three separate tests. Each test will pass if ``IsPrime`` returns false, and will otherwise fail.
@ -81,6 +82,7 @@ You can run tests from the command line or using Visual Studio, whichever you pr
Visual Studio Visual Studio
^^^^^^^^^^^^^ ^^^^^^^^^^^^^
To run tests in Visual Studio, first open the Test Explorer tab, then build the solution to have it discover all available tests. Once you have done so, you should see all of your tests in the Test Explorer window. Click Run All to run the tests and see the results. To run tests in Visual Studio, first open the Test Explorer tab, then build the solution to have it discover all available tests. Once you have done so, you should see all of your tests in the Test Explorer window. Click Run All to run the tests and see the results.
.. image:: unit-testing/_static/test-explorer.png .. image:: unit-testing/_static/test-explorer.png
@ -89,11 +91,10 @@ If you click the icon in the top-left, Visual Studio will run tests after every
Command Line Command Line
^^^^^^^^^^^^ ^^^^^^^^^^^^
To run tests from the command line, navigate to your unit test project folder. Next, run
.. code-block:: powershell To run tests from the command line, navigate to your unit test project folder. Next, run::
dnx test dnx test
You should see output similar to the following: You should see output similar to the following:
@ -101,15 +102,12 @@ You should see output similar to the following:
dnx-watch dnx-watch
^^^^^^^^^ ^^^^^^^^^
You can use the ``dnx-watch`` command to automatically execute a dnx command whenever the contents of the folder change. This can be used to automatically run tests whenever files are saved in the project. Note that it will detect changes to both the SUT project and the test project, even when run from the test project folder.
.. note:: Learn more about `getting started with dnx-watch <http://ardalis.com/get-started-with-dnx-watch>`_. You can use the ``dnx-watch`` command to automatically execute a DNX command whenever the contents of the folder change. This can be used to automatically run tests whenever files are saved in the project. Note that it will detect changes to both the SUT project and the test project, even when run from the test project folder.
To use ``dnx-watch``, simply run it and pass it the command argument you would otherwise have passed to ``dnx``. In this case: To use ``dnx-watch``, simply run it and pass it the command argument you would otherwise have passed to ``dnx``. In this case::
.. code-block:: powershell dnx-watch test
dnx-watch test
With dnx-watch running, you can make updates to your tests and/or your application, and upon saving your changes you should see the tests run again, as shown here: With dnx-watch running, you can make updates to your tests and/or your application, and upon saving your changes you should see the tests run again, as shown here:
@ -119,14 +117,9 @@ One of the major benefits of automated testing is the rapid feedback tests provi
.. tip:: View the `sample <https://github.com/aspnet/docs/tree/1.0.0-beta8/aspnet/testing/unit-testing/sample>`_ to see the complete set of tests and service behavior. You can run the web application and navigate to ``/checkprime?5`` to test whether numbers are prime. You can learn more about testing and refactoring this checkprime web behavior in :doc:`integration-testing`. .. tip:: View the `sample <https://github.com/aspnet/docs/tree/1.0.0-beta8/aspnet/testing/unit-testing/sample>`_ to see the complete set of tests and service behavior. You can run the web application and navigate to ``/checkprime?5`` to test whether numbers are prime. You can learn more about testing and refactoring this checkprime web behavior in :doc:`integration-testing`.
Summary
-------
Unit tests provide fast verification of small units of behavior within applications. They should test only code the application developer has written, and should not depend on infrastructure concerns. ASP.NET 5 is extremely testable, and developers can run unit tests from a variety of test frameworks using Visual Studio or command line tools.
Additional Resources Additional Resources
-------------------- --------------------
- :doc:`integration-testing` - :doc:`integration-testing`
- :doc:`/fundamentals/dependency-injection` - :doc:`/fundamentals/dependency-injection`
- `Unit Test Naming Convention <http://ardalis.com/unit-test-naming-convention>`_