Algorithms_in_C++ 1.0.0
Set of algorithms implemented in C++.
Loading...
Searching...
No Matches
TestCases Class Reference

class encapsulating the necessary test cases More...

Public Member Functions

void runTests ()
 Executes test cases.
 
void testCase_1 ()
 A test case contains edge case, printing inorder successor of last node.
 
void testCase_2 ()
 A test case which contains main list of 100 elements and sublist of 20.
 
void testCase_3 ()
 A test case which contains main list of 50 elements and sublist of 20.
 
void runTests ()
 Executes test cases.
 
void testCase_1 ()
 A test case contains edge case, Only contains one element.
 
void testCase_2 ()
 A test case which contains main list of 100 elements and sublist of 20.
 
void testCase_3 ()
 A test case which contains main list of 50 elements and sublist of 20.
 
void runTests ()
 Executes test cases.
 
void testCase_1 ()
 A test case with single input.
 
void testCase_2 ()
 A test case with input array of length 500.
 
void testCase_3 ()
 A test case with array of length 1000.
 

Private Member Functions

template<typename T >
void log (T msg)
 A function to print given message on console.
 
template<typename T >
void log (T msg)
 A function to print given message on console.
 
template<typename T >
void log (T msg)
 A function to print64_t given message on console.
 

Detailed Description

class encapsulating the necessary test cases

a class containing the necessary test cases

Member Function Documentation

◆ log() [1/3]

template<typename T >
void TestCases::log ( T msg)
inlineprivate

A function to print given message on console.

Template Parameters
TType of the given message.
Returns
void
233 {
234 // It's just to avoid writing cout and endl
235 std::cout << "[TESTS] : ---> " << msg << std::endl;
236 }
T endl(T... args)
Here is the call graph for this function:

◆ log() [2/3]

template<typename T >
void TestCases::log ( T msg)
inlineprivate

A function to print given message on console.

Template Parameters
TType of the given message.
Returns
void
175 {
176 // It's just to avoid writing cout and endl
177 std::cout << "[TESTS] : ---> " << msg << std::endl;
178 }
Here is the call graph for this function:

◆ log() [3/3]

template<typename T >
void TestCases::log ( T msg)
inlineprivate

A function to print64_t given message on console.

Template Parameters
TType of the given message.
Returns
void
189 {
190 // It's just to avoid writing cout and endl
191 std::cout << "[TESTS] : ---> " << msg << std::endl;
192 }
Here is the call graph for this function:

◆ runTests() [1/3]

void TestCases::runTests ( )
inline

Executes test cases.

Returns
void
243 {
244 log("Running Tests...");
245
246 testCase_1();
247 testCase_2();
248 testCase_3();
249
250 log("Test Cases over!");
252 }
void log(T msg)
A function to print given message on console.
Definition inorder_successor_of_bst.cpp:233
void testCase_2()
A test case which contains main list of 100 elements and sublist of 20.
Definition inorder_successor_of_bst.cpp:304
void testCase_1()
A test case contains edge case, printing inorder successor of last node.
Definition inorder_successor_of_bst.cpp:259
void testCase_3()
A test case which contains main list of 50 elements and sublist of 20.
Definition inorder_successor_of_bst.cpp:345
Here is the call graph for this function:

◆ runTests() [2/3]

void TestCases::runTests ( )
inline

Executes test cases.

Returns
void
185 {
186 log("Running Tests...");
187
188 testCase_1();
189 testCase_2();
190 testCase_3();
191
192 log("Test Cases over!");
194 }
Here is the call graph for this function:

◆ runTests() [3/3]

void TestCases::runTests ( )
inline

Executes test cases.

Returns
void
199 {
200 log("Running Tests...");
201
202 testCase_1();
203 testCase_2();
204 testCase_3();
205
206 log("Test Cases over!");
208 }
Here is the call graph for this function:

◆ testCase_1() [1/3]

void TestCases::testCase_1 ( )
inline

A test case contains edge case, printing inorder successor of last node.

Returns
void

< Expected output of this test

< Data to make nodes in BST

< Adding nodes to BST

< Printing inorder to cross-verify.

< The inorder successor node for given data

memory cleanup!

259 {
261 *expectedOutput = nullptr; ///< Expected output of this test
262
263 log("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~");
264 log("This is test case 1 : ");
265 log("Description:");
266 log(" EDGE CASE : Printing inorder successor for last node in the "
267 "BST, Output will be nullptr.");
268
270 nullptr;
271 std::vector<int64_t> node_data{
272 20, 3, 5, 6, 2, 23, 45, 78, 21}; ///< Data to make nodes in BST
273
275 root,
276 node_data); ///< Adding nodes to BST
277
278 std::cout << "Inorder sequence is : ";
280 root); ///< Printing inorder to cross-verify.
282
284 *inorderSuccessor = operations_on_datastructures::
285 inorder_traversal_of_bst::getInorderSuccessor(
286 root, 78); ///< The inorder successor node for given data
287
288 log("Checking assert expression...");
289 assert(inorderSuccessor == expectedOutput);
290 log("Assertion check passed!");
291
293 root); /// memory cleanup!
294
295 log("[PASS] : TEST CASE 1 PASS!");
296 log("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~");
297 }
A Node structure representing a single node in BST.
Definition inorder_successor_of_bst.cpp:56
Node * makeBST(Node *root, const std::vector< int64_t > &data)
This function is used in test cases to quickly create BST containing large data instead of hard codin...
Definition inorder_successor_of_bst.cpp:155
void printInorder(Node *root)
Prints the BST in inorder traversal using recursion.
Definition inorder_successor_of_bst.cpp:136
void deallocate(Node *rootNode)
This function clears the memory allocated to entire tree recursively. Its just for clean up the memor...
Definition inorder_successor_of_bst.cpp:210
Here is the call graph for this function:

◆ testCase_1() [2/3]

void TestCases::testCase_1 ( )
inline

A test case contains edge case, Only contains one element.

Returns
void

< Expected output of this test

< Data to make linked list which will be the sublist

< Data to make linked list which will be the main list

< Sublist to be searched

< Main list in which sublist is to be searched

< boolean, if sublist exist or not

200 {
201 const bool expectedOutput = true; ///< Expected output of this test
202
203 log("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"
204 "~");
205 log("This is test case 1 for sublist search Algorithm : ");
206 log("Description:");
207 log(" EDGE CASE : Only contains one element");
208
209 std::vector<uint64_t> sublistData = {
210 6}; ///< Data to make linked list which will be the sublist
211 std::vector<uint64_t> mainlistData = {
212 2, 5, 6, 7,
213 8}; ///< Data to make linked list which will be the main list
214
217 sublistData); ///< Sublist to be searched
218 search::sublist_search::Node *mainlistLL =
220 mainlistData); ///< Main list in which sublist is to be
221 ///< searched
222
224 sublistLL, mainlistLL); ///< boolean, if sublist exist or not
225
226 log("Checking assert expression...");
227 assert(exists == expectedOutput);
228 log("Assertion check passed!");
229
230 log("[PASS] : TEST CASE 1 PASS!");
231 log("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"
232 "~");
233
234 deleteList(mainlistLL);
235 deleteList(sublistLL);
236 }
A Node structure representing a single link Node in a linked list.
Definition sublist_search.cpp:47
bool sublistSearch(Node *sublist, Node *mainList)
Main searching function.
Definition sublist_search.cpp:114
Node * makeLinkedList(const std::vector< uint64_t > &data)
Give a vector of data, it adds each element of vector in the linked list and return the address of he...
Definition sublist_search.cpp:73
bool exists(const std::string &str, const std::unordered_set< std::string > &strSet)
Function that checks if the string passed in param is present in the the unordered_set passed.
Definition word_break.cpp:60
Here is the call graph for this function:

◆ testCase_1() [3/3]

void TestCases::testCase_1 ( )
inline

A test case with single input.

Returns
void
214 {
215 const int64_t inputSize = 1;
216 log("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"
217 "~");
218 log("This is test case 1 for Random Pivot Quick Sort Algorithm : ");
219 log("Description:");
220 log(" EDGE CASE : Only contains one element");
221 std::array<int64_t, inputSize> unsorted_arr{2};
222
223 int64_t start = 0;
224 int64_t end = unsorted_arr.size() - 1; // length - 1
225
226 log("Running algorithm of data of length 50 ...");
227 std::array<int64_t, unsorted_arr.size()> sorted_arr =
229 end);
230 log("Algorithm finished!");
231
232 log("Checking assert expression...");
233 assert(std::is_sorted(sorted_arr.begin(), sorted_arr.end()));
234 log("Assertion check passed!");
235
236 log("[PASS] : TEST CASE 1 PASS!");
237 log("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"
238 "~");
239 }
T end(T... args)
T is_sorted(T... args)
std::array< int64_t, size > quickSortRP(std::array< int64_t, size > arr, int64_t start, int64_t end)
Random pivot quick sort function. This function is the starting point of the algorithm.
Definition random_pivot_quick_sort.cpp:130
T size(T... args)
Here is the call graph for this function:

◆ testCase_2() [1/3]

void TestCases::testCase_2 ( )
inline

A test case which contains main list of 100 elements and sublist of 20.

Returns
void

< Expected output of this test

< Data to make nodes in BST

< Adding nodes to BST

< Printing inorder to cross-verify.

< The inorder successor node for given data

memory cleanup!

304 {
305 const int expectedOutput = 21; ///< Expected output of this test
306
307 log("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~");
308 log("This is test case 2 : ");
309
311 nullptr;
312 std::vector<int64_t> node_data{
313 20, 3, 5, 6, 2, 23, 45, 78, 21}; ///< Data to make nodes in BST
314
316 root,
317 node_data); ///< Adding nodes to BST
318
319 std::cout << "Inorder sequence is : ";
321 root); ///< Printing inorder to cross-verify.
323
325 *inorderSuccessor = operations_on_datastructures::
326 inorder_traversal_of_bst::getInorderSuccessor(
327 root, 20); ///< The inorder successor node for given data
328
329 log("Checking assert expression...");
330 assert(inorderSuccessor->data == expectedOutput);
331 log("Assertion check passed!");
332
334 root); /// memory cleanup!
335
336 log("[PASS] : TEST CASE 2 PASS!");
337 log("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~");
338 }
int64_t data
The key/value of the node.
Definition inorder_successor_of_bst.cpp:58
Here is the call graph for this function:

◆ testCase_2() [2/3]

void TestCases::testCase_2 ( )
inline

A test case which contains main list of 100 elements and sublist of 20.

Returns
void

Expected output of this test

< Data to make linked list which will be the sublist

< Main list in which sublist is to be searched

Inserts 100 elements in main list

Inserts 20 elements in sublist

< Sublist to be searched

< Main list in which sublist is to be searched

< boolean, if sublist exist or not

243 {
244 const bool expectedOutput = true; /// Expected output of this test
245
246 log("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"
247 "~");
248 log("This is test case 2 for sublist search Algorithm : ");
249 log("Description:");
250 log(" contains main list of 100 elements and sublist of 20");
251
252 std::vector<uint64_t> sublistData(
253 20); ///< Data to make linked list which will be the sublist
254 std::vector<uint64_t> mainlistData(
255 100); ///< Main list in which sublist is to be searched
256
257 for (int i = 0; i < 100; i++) {
258 /// Inserts 100 elements in main list
259 mainlistData[i] = i + 1;
260 }
261
262 int temp = 0;
263 for (int i = 45; i < 65; i++) {
264 /// Inserts 20 elements in sublist
265 sublistData[temp] = i + 1;
266 temp++;
267 }
268
271 sublistData); ///< Sublist to be searched
272 search::sublist_search::Node *mainlistLL =
274 mainlistData); ///< Main list in which sublist is to be
275 ///< searched
276
278 sublistLL, mainlistLL); ///< boolean, if sublist exist or not
279
280 log("Checking assert expression...");
281 assert(exists == expectedOutput);
282 log("Assertion check passed!");
283
284 log("[PASS] : TEST CASE 2 PASS!");
285 log("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"
286 "~");
287
288 deleteList(mainlistLL);
289 deleteList(sublistLL);
290 }
Here is the call graph for this function:

◆ testCase_2() [3/3]

void TestCases::testCase_2 ( )
inline

A test case with input array of length 500.

Returns
void
245 {
246 const int64_t inputSize = 500;
247 log("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"
248 "~");
249 log("Description:");
250 log(" BIG INPUT : Contains 500 elements and repeated elements");
251 log("This is test case 2 for Random Pivot Quick Sort Algorithm : ");
252 std::array<int64_t, inputSize> unsorted_arr =
253 sorting::random_pivot_quick_sort::generateUnsortedArray<inputSize>(
254 1, 10000);
255
256 int64_t start = 0;
257 int64_t end = unsorted_arr.size() - 1; // length - 1
258
259 log("Running algorithm of data of length 500 ...");
260 std::array<int64_t, unsorted_arr.size()> sorted_arr =
262 end);
263 log("Algorithm finished!");
264
265 log("Checking assert expression...");
266 assert(std::is_sorted(sorted_arr.begin(), sorted_arr.end()));
267 log("Assertion check passed!");
268
269 log("[PASS] : TEST CASE 2 PASS!");
270 log("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"
271 "~");
272 }
Here is the call graph for this function:

◆ testCase_3() [1/3]

void TestCases::testCase_3 ( )
inline

A test case which contains main list of 50 elements and sublist of 20.

Returns
void

< Expected output of this test

< Data to make nodes in BST

< Adding nodes to BST

< Printing inorder to cross-verify.

< The inorder successor node for given data

memory cleanup!

345 {
346 const int expectedOutput = 110; ///< Expected output of this test
347
348 log("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~");
349 log("This is test case 3 : ");
350
352 nullptr;
353 std::vector<int64_t> node_data{
354 89, 67, 32, 56, 90, 123, 120,
355 110, 115, 6, 78, 7, 10}; ///< Data to make nodes in BST
356
358 root,
359 node_data); ///< Adding nodes to BST
360
361 std::cout << "Inorder sequence is : ";
363 root); ///< Printing inorder to cross-verify.
365
367 *inorderSuccessor = operations_on_datastructures::
368 inorder_traversal_of_bst::getInorderSuccessor(
369 root, 90); ///< The inorder successor node for given data
370
371 log("Checking assert expression...");
372 assert(inorderSuccessor->data == expectedOutput);
373 log("Assertion check passed!");
374
376 root); /// memory cleanup!
377
378 log("[PASS] : TEST CASE 3 PASS!");
379 log("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~");
380 }
Here is the call graph for this function:

◆ testCase_3() [2/3]

void TestCases::testCase_3 ( )
inline

A test case which contains main list of 50 elements and sublist of 20.

Returns
void

< Expected output of this test

< Sublist to be searched

< Main list in which sublist is to be searched

Inserts 100 elements in main list

Inserts 20 elements in sublist

< Sublist to be searched

< Main list in which sublist is to be searched

< boolean, if sublist exist or not

297 {
298 const bool expectedOutput = false; ///< Expected output of this test
299
300 log("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"
301 "~");
302 log("This is test case 3 for sublist search Algorithm : ");
303 log("Description:");
304 log(" contains main list of 50 elements and sublist of 20");
305
306 std::vector<uint64_t> sublistData(20); ///< Sublist to be searched
307 std::vector<uint64_t> mainlistData(
308 50); ///< Main list in which sublist is to be searched
309
310 for (int i = 0; i < 50; i++) {
311 /// Inserts 100 elements in main list
312 mainlistData.push_back(i + 1);
313 }
314
315 for (int i = 45; i < 65; i++) {
316 /// Inserts 20 elements in sublist
317 sublistData.push_back(i + 1);
318 }
319
322 sublistData); ///< Sublist to be searched
323 search::sublist_search::Node *mainlistLL =
325 mainlistData); ///< Main list in which sublist is to be
326 ///< searched
327
329 sublistLL, mainlistLL); ///< boolean, if sublist exist or not
330
331 log("Checking assert expression...");
332 assert(exists == expectedOutput);
333 log("Assertion check passed!");
334
335 log("[PASS] : TEST CASE 3 PASS!");
336 log("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"
337 "~");
338
339 deleteList(mainlistLL);
340 deleteList(sublistLL);
341 }
Here is the call graph for this function:

◆ testCase_3() [3/3]

void TestCases::testCase_3 ( )
inline

A test case with array of length 1000.

Returns
void
278 {
279 const int64_t inputSize = 1000;
280 log("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"
281 "~");
282 log("This is test case 3 for Random Pivot Quick Sort Algorithm : ");
283 log("Description:");
284 log(" LARGE INPUT : Contains 1000 elements and repeated elements");
285 std::array<int64_t, inputSize> unsorted_arr =
286 sorting::random_pivot_quick_sort::generateUnsortedArray<inputSize>(
287 1, 10000);
288
289 int64_t start = 0;
290 int64_t end = unsorted_arr.size() - 1; // length - 1
291
292 log("Running algorithm...");
293 std::array<int64_t, unsorted_arr.size()> sorted_arr =
295 end);
296 log("Algorithm finished!");
297
298 log("Checking assert expression...");
299 assert(std::is_sorted(sorted_arr.begin(), sorted_arr.end()));
300 log("Assertion check passed!");
301
302 log("[PASS] : TEST CASE 3 PASS!");
303 log("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"
304 "~");
305 }
Here is the call graph for this function:

The documentation for this class was generated from the following files: