user exist: simplify expression, add unit test

Simplified two boolean expression and added unit tests. The unit test
container has the root user by default and can be leveraged in the unit
test.

Tested: unit test passed.

Signed-off-by: Nan Zhou <nanzhoumails@gmail.com>
Change-Id: Ia335ad9e14e5cdeca5c260ef67f308f7197be349
diff --git a/user_mgr.hpp b/user_mgr.hpp
index ac163f7..dd73fff 100644
--- a/user_mgr.hpp
+++ b/user_mgr.hpp
@@ -66,6 +66,10 @@
 
 bool removeStringFromCSV(std::string& csvStr, const std::string& delStr);
 
+template <typename... ArgTypes>
+static std::vector<std::string> executeCmd(const char* path,
+                                           ArgTypes&&... tArgs);
+
 /** @class UserMgr
  *  @brief Responsible for managing user accounts over the D-Bus interface.
  */
@@ -220,6 +224,28 @@
                              const std::string& argName,
                              const std::string& argValue);
 
+    /** @brief check for user presence
+     *  method to check for user existence
+     *
+     *  @param[in] userName - name of the user
+     *  @return -true if user exists and false if not.
+     */
+    bool isUserExist(const std::string& userName);
+
+    /** @brief check user exists
+     *  method to check whether user exist, and throw if not.
+     *
+     *  @param[in] userName - name of the user
+     */
+    void throwForUserDoesNotExist(const std::string& userName);
+
+    /** @brief check user does not exist
+     *  method to check whether does not exist, and throw if exists.
+     *
+     *  @param[in] userName - name of the user
+     */
+    void throwForUserExists(const std::string& userName);
+
   private:
     /** @brief sdbusplus handler */
     sdbusplus::bus_t& bus;
@@ -255,28 +281,6 @@
      */
     UserSSHLists getUserAndSshGrpList(void);
 
-    /** @brief check for user presence
-     *  method to check for user existence
-     *
-     *  @param[in] userName - name of the user
-     *  @return -true if user exists and false if not.
-     */
-    bool isUserExist(const std::string& userName);
-
-    /** @brief check user exists
-     *  method to check whether user exist, and throw if not.
-     *
-     *  @param[in] userName - name of the user
-     */
-    void throwForUserDoesNotExist(const std::string& userName);
-
-    /** @brief check user does not exist
-     *  method to check whether does not exist, and throw if exists.
-     *
-     *  @param[in] userName - name of the user
-     */
-    void throwForUserExists(const std::string& userName);
-
     /** @brief check user name constraints
      *  method to check user name constraints and throw if failed.
      *