-
Notifications
You must be signed in to change notification settings - Fork 1.4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Event and alarm management #17949
Merged
Merged
Event and alarm management #17949
Changes from 5 commits
Commits
Show all changes
9 commits
Select commit
Hold shift + click to select a range
20ec442
Support for event persistence in redis-db.
bhaveshdell b314160
Updates
bhaveshdell e724cb4
Updates including fix to eventdb in test enviroment.
bhaveshdell 4a6ccdb
Add sonic yang to model event and alarm table.
bhaveshdell 28656eb
Add event/alarm persistence related testscases
bhaveshdell eca9741
Remove file eventdb_ut.cpp.
bhaveshdell c9ab66d
Updates to eventdb testsuite.
bhaveshdell 048a056
Revert changes to existing eventd UT.
bhaveshdell cdfe814
Commit test related config files.
bhaveshdell File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,107 @@ | ||
#include<string> | ||
#include "gtest/gtest.h" | ||
#include "events_common.h" | ||
#include "events.h" | ||
#include "../src/eventd.h" | ||
#include "../src/eventconsume.h" | ||
|
||
using namespace std; | ||
using namespace swss; | ||
|
||
typedef struct { | ||
int key; | ||
string type-id; | ||
string resource; | ||
string action; | ||
string text; | ||
} event_data_t; | ||
|
||
static const event_data_t events[] = { | ||
{1, "SYSTEM_STATE", "System", "", "System Ready"}, | ||
{2, "USER_LOGIN", "ssh", "", "user testuser logged in"}, | ||
}; | ||
|
||
static const event_data_t alarms[] = { | ||
{1, "TEMP_THRESHOLD_HIGH", "CPU_SENSOR", "RAISE", "Temperature cross threshold 50C"}, | ||
{2, "INTERFACE_OPER_STATE", "eth1", "RAISE", "Operational Down"}, | ||
{3, "INTERFACE_OPER_STATE", "eth1", "CLEAR", "Operational Down"}, | ||
{4, "TEMP_THRESHOLD_HIGH", "CPU_SENSOR", "CLEAR", "Temperature cross threshold 50C"}, | ||
|
||
}; | ||
|
||
const string event_profile = "default_event.json"; | ||
const string event_db_profile = "event_db.json"; | ||
|
||
//typedef unordered_map<string, string> params; | ||
|
||
//params events_lst[] = [("id":" 1", "type-id": SYSTEM_STATE, "resource": "System", "text": "System Ready", "severity" : "INFORMATIONAL"}, | ||
// {"id":"2", "type-id": USER_LOGIN, "resource": "SSH", "text": "User login", "severity": "WARNING"}]; | ||
/* | ||
1) "time-created" | ||
2) "1706507049241598976" | ||
3) "type-id" | ||
4) "SYSTEM_STATUS" | ||
5) "text" | ||
6) "System is ready" | ||
7) "resource" | ||
8) "system_status" | ||
9) "severity" | ||
10) "INFORMATIONAL" | ||
11) "id" | ||
12) "4" | ||
*/ | ||
|
||
class EventDbFixture : public ::testing::Environment { | ||
protected: | ||
void SetUp() override { | ||
zctx = zmq_ctx_new(); | ||
EXPECT_TRUE(NULL != zctx); | ||
|
||
/* Run proxy to enable receive as capture test needs to receive */ | ||
eventd_proxy *pxy = new eventd_proxy(zctx); | ||
EXPECT_TRUE(NULL != pxy); | ||
|
||
/* Starting proxy */ | ||
EXPECT_EQ(0, pxy->init()); | ||
|
||
/* Start Eventdb in a separate thread*/ | ||
swss::DBConnector eventDb("EVENT_DB", 0); | ||
|
||
EventConsume evtd(&eventDb, event_profile, event_db_profile); | ||
thread thr(&EventConsume::run, &evtd); | ||
} | ||
|
||
void TearDown() override { | ||
|
||
} | ||
void *zctx; | ||
} | ||
|
||
void *init_publish(void *zctx) | ||
{ | ||
void *mock_pub = zmq_socket (zctx, ZMQ_PUB); | ||
EXPECT_TRUE(NULL != mock_pub); | ||
EXPECT_EQ(0, zmq_connect(mock_pub, get_config(XSUB_END_KEY).c_str())); | ||
|
||
/* Provide time for async connect to complete */ | ||
this_thread::sleep_for(chrono::milliseconds(200)); | ||
|
||
return mock_pub; | ||
} | ||
|
||
|
||
TEST_F(EventDbFixture, validate_events) | ||
{ | ||
DBConnector db("EVENT_DB", 0, true); | ||
void* pub_handle = init_publish(zctx); | ||
// pub_handle = events_init_publisher("test_db"); | ||
for(int i = 0; i < ARRAY_SIZE(events); i++) { | ||
string tag = string("test_db_tag_") + to_string(i); | ||
const event_params_t params = {{"type-id", events[i].type-id}, | ||
{ "resource", events[i].resource}, | ||
{ "action", events[i].action}, | ||
{ "text", events[i].text}}; | ||
|
||
event_publish(pub_handle, tag, ¶ms); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,6 @@ | ||
usr/bin/eventd | ||
usr/bin/eventdb | ||
usr/bin/events_tool | ||
usr/bin/events_publish_tool.py | ||
etc/evprofile/default.json | ||
etc/eventd.json |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
{ | ||
"__README__": "Specify size of event history table. Whichever limit is hit first, eventd wraps event history table around and deletes older records.", | ||
"max-records": 40000, | ||
"max-days": 30 | ||
} |
Oops, something went wrong.
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This a new redis DB instance addition. Have few queries:
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.