A Discrete-Event Network Simulator
API
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
li-ion-energy-source-test.cc
Go to the documentation of this file.
1 /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2 /*
3  * Copyright (c) 2010 Andrea Sacco
4  *
5  * This program is free software; you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License version 2 as
7  * published by the Free Software Foundation;
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software
16  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17  *
18  * Author: Andrea Sacco <andrea.sacco85@gmail.com>
19  */
20 
21 #include "ns3/log.h"
22 #include "ns3/test.h"
23 #include "ns3/simple-device-energy-model.h"
24 #include "ns3/li-ion-energy-source.h"
25 #include "ns3/node.h"
26 #include "ns3/simulator.h"
27 
28 namespace ns3 {
29 
30 NS_LOG_COMPONENT_DEFINE ("LiIonEnergySourceTestSuite")
31  ;
32 
34 {
35 public:
38 
39  void DoRun (void);
40 
41  double m_simTime;
43 };
44 
46  : TestCase ("Li-Ion energy source test case")
47 {
48 }
49 
51 {
52  m_node = 0;
53 }
54 
55 void
57 {
58  m_node = CreateObject<Node> ();
59 
60  Ptr<SimpleDeviceEnergyModel> sem = CreateObject<SimpleDeviceEnergyModel> ();
61  Ptr<LiIonEnergySource> es = CreateObject<LiIonEnergySource> ();
62 
63  es->SetNode (m_node);
64  sem->SetEnergySource (es);
65  es->AppendDeviceEnergyModel (sem);
66  m_node->AggregateObject (es);
67 
68  Time now = Simulator::Now ();
69 
70  // discharge at 2.33 A for 1700 seconds
71  sem->SetCurrentA (2.33);
72  now += Seconds (1701);
73 
74  Simulator::Stop (now);
75  Simulator::Run ();
77 
78  NS_TEST_ASSERT_MSG_EQ_TOL (es->GetSupplyVoltage (), 3.6, 1.0e-3,
79  "Incorrect consumed energy!");
80 }
81 
83 {
84 public:
86 };
87 
89  : TestSuite ("li-ion-energy-source", UNIT)
90 {
92 }
93 
94 // create an instance of the test suite
96 
97 } // namespace ns3
keep track of time values and allow control of global simulation resolution
Definition: nstime.h:81
NS_LOG_COMPONENT_DEFINE("GrantedTimeWindowMpiInterface")
static LiIonEnergySourceTestSuite g_liIonEnergySourceTestSuite
#define NS_TEST_ASSERT_MSG_EQ_TOL(actual, limit, tol, msg)
Test that actual and expected (limit) values are equal to plus or minus some tolerance and report and...
Definition: test.h:326
A suite of tests to run.
Definition: test.h:1025
static void Run(void)
Run the simulation until one of:
Definition: simulator.cc:157
encapsulates test code
Definition: test.h:849
void AggregateObject(Ptr< Object > other)
Definition: object.cc:243
static void Destroy(void)
Every event scheduled by the Simulator::insertAtDestroy method is invoked.
Definition: simulator.cc:121
void DoRun(void)
Implementation to actually run this TestCase.
static Time Now(void)
Return the "current simulation time".
Definition: simulator.cc:180
void AddTestCase(TestCase *testCase) NS_DEPRECATED
Add an individual child TestCase case to this TestCase.
Definition: test.cc:173
Fast test.
Definition: test.h:857
static void Stop(void)
If an event invokes this method, it will be the last event scheduled by the Simulator::run method bef...
Definition: simulator.cc:165