From 2769a3a0ad430ccc72479b4562bb92272a7da3c9 Mon Sep 17 00:00:00 2001 From: Imbus <> Date: Thu, 5 Dec 2024 12:32:27 +0100 Subject: [PATCH] Prettier search, tests --- lab3/UserTable.cc | 14 ++++++-------- lab3/UserTableTest.cc | 45 +++++++++++++++++++++++++++++-------------- 2 files changed, 37 insertions(+), 22 deletions(-) diff --git a/lab3/UserTable.cc b/lab3/UserTable.cc index 7e0dd1e..542cd0d 100644 --- a/lab3/UserTable.cc +++ b/lab3/UserTable.cc @@ -68,14 +68,12 @@ User UserTable::find(int c) const { return found ? users[mid] : user_not_found; } User UserTable::find(std::string name) const { - for (int i = 0; i != n; ++i) { - if (users[i].getName() == name) { - return users[i]; - } else { - return user_not_found; - } - } - return user_not_found; + auto it = std::find_if(users, users + n, [&name](const User &u) { + return u.getName() == name; + }); + + // If it is at the 'end' of users, the result is not found + return (it != users+n) ? *it : user_not_found; } void UserTable::ensureCapacity(int s) { diff --git a/lab3/UserTableTest.cc b/lab3/UserTableTest.cc index 98ccacf..b50200b 100644 --- a/lab3/UserTableTest.cc +++ b/lab3/UserTableTest.cc @@ -3,23 +3,40 @@ #include int main() { - // Two identical users - User u1 = User(1234, "Name Nameson"); - User u2 = User(1234, "Name Nameson"); + { /* User Related Tests */ + // Two identical users + User u1 = User(1234, "Name Nameson"); + User u2 = User(1234, "Name Nameson"); - assert(u1.getName() == u2.getName()); - assert(u1.getCardNbr() == u2.getCardNbr()); + assert(u1.getName() == u2.getName()); + assert(u1.getCardNbr() == u2.getCardNbr()); - // Two different users - User u3 = User(1200, "Name Surname"); - User u4 = User(1201, "Name Nameson"); + // Two different users + User u3 = User(1200, "Name Surname"); + User u4 = User(1201, "Name Nameson"); - assert(u3.getName() != u4.getName()); - assert(u3.getCardNbr() != u4.getCardNbr()); + assert(u3.getName() != u4.getName()); + assert(u3.getCardNbr() != u4.getCardNbr()); + } + { /* Table Related Tests */ + UserTable tbl1 = UserTable(); + assert(tbl1.find("Jens Holmgren") == UserTable::user_not_found); + tbl1.addUser(User(1200, "Table Yes")); + assert(tbl1.getNbrUsers() == 1); + } + { + // Assumes 'users.txt' is present, containing + // line separated records formatted as: + // "89524 Adam Abrahamsson" + UserTable tbl = UserTable("users.txt"); + assert(tbl.getNbrUsers() > 0); + assert(tbl.find("Jens Holmgren") != UserTable::user_not_found); - UserTable ut1 = UserTable("users.txt"); + tbl.addUser(User(1200, "Name Surname")); + User ufind1 = tbl.find(1200); + assert(ufind1 != UserTable::user_not_found); - ut1.addUser(u3); - User us = ut1.find(1200); - assert(us != UserTable::user_not_found); + User ufind2 = tbl.find("Name Surname"); + assert(ufind2 != UserTable::user_not_found); + } }