Add oem folder for verify special sensor name

Changes:
        -Add "data/oem/ieisystem/sensors_resource.json".
        -Add "oem/ieisystem/test_sensor_monitoring.robot".

Tested:
        -Ran and Tested on ieisystem bmc Environment.

Change-Id: I7a9c6e8c1cfd5afbbd0f6da0a69aef2b1db7c02e
Signed-off-by: Guowei Zheng <zhengguowei@ieisystem.com>
Signed-off-by: Chicago Duan <duanzhijia01@ieisystem.com>
diff --git a/oem/ieisystem/test_sensor_monitoring.robot b/oem/ieisystem/test_sensor_monitoring.robot
new file mode 100644
index 0000000..a55258e
--- /dev/null
+++ b/oem/ieisystem/test_sensor_monitoring.robot
@@ -0,0 +1,247 @@
+*** Settings ***
+Documentation    Test Redfish sensor monitoring.
+
+Resource         ../../lib/resource.robot
+Resource         ../../lib/bmc_redfish_resource.robot
+Resource         ../../lib/bmc_redfish_utils.robot
+Library          ../../lib/gen_robot_print.py
+Library          ../../lib/utils.py
+
+Test Setup       Test Setup Execution
+Test Teardown    Test Teardown Execution
+Test Tags        Test_Sensor_Monitoring
+
+*** Variables ***
+
+@{INVALID_SENSORS}
+${OPENBMC_CONN_METHOD}  ssh
+${IPMI_COMMAND}         Inband
+
+** Test Cases **
+
+Verify Sensor Monitoring
+    [Documentation]  Verify the redfish sensor monitoring according to the BMC
+    ...              expected SDR table.
+    [Tags]  Verify_Sensor_Monitoring
+
+    # Check whether the expected sensors are present in the Redfish request.
+    # Check whether the sensors's 'Health' is 'OK' and the 'State' is 'Enabled'.
+    # Check sensor reading is not equal to null.
+
+    ${resp}=  Redfish.Get  /redfish/v1/Chassis/${CHASSIS_ID}
+    ...  valid_status_codes=[${HTTP_OK}]
+
+   Should Be Equal As Strings  ${resp.dict['Oem']['Public']['DiscreteSensors']['@odata.id']}
+   ...  /redfish/v1/Chassis/${CHASSIS_ID}/DiscreteSensors
+   Should Be Equal As Strings  ${resp.dict['Oem']['Public']['ThresholdSensors']['@odata.id']}
+   ...  /redfish/v1/Chassis/${CHASSIS_ID}/ThresholdSensors
+   Should Be Equal As Strings  ${resp.dict['Thermal']['@odata.id']}
+   ...  /redfish/v1/Chassis/${CHASSIS_ID}/Thermal
+   Should Be Equal As Strings  ${resp.dict['Power']['@odata.id']}
+   ...  /redfish/v1/Chassis/${CHASSIS_ID}/Power
+
+    # Check sensors in /redfish/v1/Chassis/{ChassisId}/Power
+    ${resp}=  Redfish.Get  /redfish/v1/Chassis/${CHASSIS_ID}/Power
+    ...  valid_status_codes=[${HTTP_OK}]
+
+    Check If Expected Sensors Are Present  ${resp.dict['Voltages']}  Voltages
+    Check Sensor Status And Reading Via Sensor Info
+    ...  ${resp.dict['Voltages']}  ReadingVolts
+
+    # Check sensors in /redfish/v1/Chassis/{ChassisId}/Thermal
+    ${resp}=  Redfish.Get  /redfish/v1/Chassis/${CHASSIS_ID}/Thermal
+    ...  valid_status_codes=[${HTTP_OK}]
+
+    Check If Expected Sensors Are Present  ${resp.dict['Temperatures']}  Temperatures
+    Check If Expected Sensors Are Present  ${resp.dict['Fans']}  Fans
+
+    Check Sensor Status And Reading Via Sensor Info
+    ...  ${resp.dict['Temperatures']}  ReadingCelsius
+    Check Sensor Status And Reading Via Sensor Info
+    ...  ${resp.dict['Fans']}  Reading
+
+    # Check sensors in
+    # /redfish/v1/Chassis/{ChassisId}/DiscreteSensors
+    ${resp}=  Redfish.Get  /redfish/v1/Chassis/${CHASSIS_ID}/DiscreteSensors
+    ...  valid_status_codes=[${HTTP_OK}]
+
+    Check If Expected Sensors Are Present  ${resp.dict['Sensors']}  DiscreteSensors
+    Check Sensor Status And Reading Via Sensor Info
+    ...  ${resp.dict['Sensors']}  Status
+
+    # Check sensors in
+    # /redfish/v1/Chassis/{ChassisId}/ThresholdSensors
+    ${resp}=  Redfish.Get  /redfish/v1/Chassis/${CHASSIS_ID}/ThresholdSensors
+    ...  valid_status_codes=[${HTTP_OK}]
+
+    Check If Expected Sensors Are Present  ${resp.dict['Sensors']}  ThresholdSensors
+    Check Sensor Status And Reading Via Sensor Info
+    ...  ${resp.dict['Sensors']}  Reading
+
+    Rprint Vars  INVALID_SENSORS
+
+    ${error_msg}=   Evaluate  ", ".join(${INVALID_SENSORS})
+    Should Be Empty  ${INVALID_SENSORS}
+    ...  msg=Test fail, invalid sensors are ${error_msg}.
+
+
+*** Keywords ***
+
+Test Teardown Execution
+    [Documentation]  Do the post test teardown.
+
+    Run Keyword And Ignore Error  Redfish.Logout
+
+
+Test Setup Execution
+    [Documentation]  Do the test setup.
+
+    Check For Required Parameters For Sensor Monitoring
+    Redfish.Login
+
+
+Check For Required Parameters For Sensor Monitoring
+    [Documentation]  Check if required parameters are provided via command line.
+
+    Should Not Be Empty   ${OS_HOST}
+    Should Not Be Empty   ${OS_USERNAME}
+    Should Not Be Empty   ${OS_PASSWORD}
+    IF  '${OPENBMC_CONN_METHOD}' == 'ssh'
+        Should Not Be Empty   ${OPENBMC_HOST}
+    ELSE IF  '${OPENBMC_CONN_METHOD}' == 'telnet'
+        Should Not Be Empty   ${OPENBMC_SERIAL_HOST}
+    ELSE
+        Fail  Invalid connection method: ${OPENBMC_CONN_METHOD}
+    END
+
+
+Get Sensors Name List From Redfish
+    [Documentation]  Get sensors name list from redfish.
+    [Arguments]  ${sensor_info_list}
+    # Description of arguments:
+    # sensor_info_list    A list of a specified sensor info return by a redfish
+    #                     request.
+
+    # An example of a sensor redfish request:
+    # /redfish/v1/Chassis/${CHASSIS_ID}/Power
+    # {
+    #     ...
+    #   "Voltages": [
+    #     {
+    #     "@odata.id": "/redfish/v1/Chassis/1/Power#/Voltages/0",
+    #     "@odata.type": "#Power.v1_7_1.Voltage",
+    #     "LowerThresholdCritical": 10.8,
+    #     "LowerThresholdFatal": 10.44,
+    #     "LowerThresholdNonCritical": 11.16,
+    #     "MaxReadingRange": 255.0,
+    #     "MemberId": "0",
+    #     "MinReadingRange": 0.0,
+    #     "Name": "P12V_CPU0_DIMM",
+    #     "ReadingVolts": null,
+    #     "Status": {
+    #         "Health": "OK",
+    #         "State": "Enabled"
+    #     },
+    #     "UpperThresholdCritical": 13.2,
+    #     "UpperThresholdFatal": 13.786,
+    #     "UpperThresholdNonCritical": 12.84
+    #     },
+
+    #     ..
+    # }
+
+    @{sensor_name_list}=  Create List
+    FOR  ${sensor_info}  IN  @{sensor_info_list}
+        Append To List  ${sensor_name_list}  ${sensor_info['Name']}
+    END
+
+    RETURN  ${sensor_name_list}
+
+
+Check Sensor Status And Reading Via Sensor Name
+    [Documentation]  Verify the sensor status and reading by sensor name,
+    ...              optionally checking if the reading is within a given range.
+    [Arguments]  ${sensor_name}
+    # Description of arguments:
+    # sensor_name    Sensor that should be present.
+
+    ${resp}=  Redfish.Get
+    ...  /redfish/v1/Chassis/${CHASSIS_ID}/Sensors/${sensor_name}
+    ...  valid_status_codes=[${HTTP_OK}, ${HTTP_NOT_FOUND}]
+
+    Run Keyword And Return If  '${resp.status}' == '${HTTP_NOT_FOUND}'
+    ...  Append To List  ${INVALID_SENSORS}  ${sensor_name}
+
+    ${condition_str}=  Catenate
+        ...  '${resp.dict['Status']['Health']}' != 'OK'
+        ...  or '${resp.dict['Status']['State']}' != 'Enabled'
+        ...  or ${resp.dict['Reading']} == ${null}
+
+    IF  ${condition_str}
+        Append To List  ${INVALID_SENSORS}  ${sensor_name}
+    END
+
+
+Check Sensor Status And Reading Via Sensor Info
+    [Documentation]  Check if each sensor's health is ok, state is enabled,
+    ...              and reading value (by unit) is not null from a redfish sensor info list.
+    [Arguments]  ${sensor_info_list}  ${reading_unit}
+    # Description of arguments:
+    # sensor_info_list  A list of a specified sensor info return by a redfish
+    #                   request.
+    # reading_unit      A string represents the reading value in sensor info
+    #                   return by a redfish request. It different between
+    #                   different sensor unit of sensor info.
+
+    FOR  ${sensor_info}  IN  @{sensor_info_list}
+        ${condition_str}=  Catenate
+        ...  '${sensor_info['Status']['Health']}' != 'OK'
+        ...  or '${sensor_info['Status']['State']}' != 'Enabled'
+        ...  or ${sensor_info['${reading_unit}']} == ${null}
+
+         IF  ${condition_str}
+             Append To List  ${INVALID_SENSORS}  ${sensor_info['Name']}
+         END
+    END
+
+
+Check If Expected Sensors Are Present
+    [Documentation]  Check that sensors are present as expected.
+    [Arguments]  ${sensor_info_list}  ${sensor_type}
+    # Description of arguments:
+    # sensor_info_list  A list of a specified sensor info return by a redfish
+    #                   request.
+    # sensor_type       A string represents the sensor category to be verified.
+
+    # An example table of expected sensors:
+    # redfish_sensor_info_map = {
+    #       "Voltages":{
+    #           "Voltage0",
+    #           ...
+    #       },
+    #       "Temperatures":{
+    #           "DIMM0",
+    #           ...
+    #       }
+    #       "Fans":{
+    #           "Fan0",
+    #           ...
+    #       }...
+    #}
+
+    ${curr_sensor_name_list}=  Get Sensors Name List From Redfish
+    ...  ${sensor_info_list}
+
+    ${code_base_dir_path}=  Get Code Base Dir Path
+    ${redfish_sensor_info_map}=  Evaluate
+    ...  json.load(open('${code_base_dir_path}data/oem/ieisystem/sensors_resource.json'))  modules=json
+
+    ${expected_sensor_name_list}=  Set Variable
+    ...  ${redfish_sensor_info_map['${sensor_type}']}
+
+    FOR  ${sensor_name}  IN  @{expected_sensor_name_list}
+        ${exist}=  Evaluate  '${sensor_name}' in ${curr_sensor_name_list}
+        IF  '${exist}' == '${False}'
+            Append To List  ${INVALID_SENSORS}  ${sensor_name}
+        END
+    END