|
1 | 1 | import time |
| 2 | +from threading import Thread |
| 3 | +from pympler.tracker import SummaryTracker |
2 | 4 | from swsscommon import swsscommon |
3 | 5 |
|
4 | 6 | def test_ProducerTable(): |
@@ -87,3 +89,36 @@ def test_DBConnectorRedisClientName(): |
87 | 89 | db.setClientName(client_name) |
88 | 90 | time.sleep(1) |
89 | 91 | assert db.getClientName() == client_name |
| 92 | + |
| 93 | + |
| 94 | +def test_SelectMemoryLeak(): |
| 95 | + N = 50000 |
| 96 | + def table_set(t, state): |
| 97 | + fvs = swsscommon.FieldValuePairs([("status", state)]) |
| 98 | + t.set("123", fvs) |
| 99 | + |
| 100 | + def generator_SelectMemoryLeak(): |
| 101 | + app_db = swsscommon.DBConnector("APPL_DB", 0, True) |
| 102 | + t = swsscommon.Table(app_db, "TABLE") |
| 103 | + for i in xrange(N/2): |
| 104 | + table_set(t, "up") |
| 105 | + table_set(t, "down") |
| 106 | + |
| 107 | + tracker = SummaryTracker() |
| 108 | + appl_db = swsscommon.DBConnector("APPL_DB", 0, True) |
| 109 | + sel = swsscommon.Select() |
| 110 | + sst = swsscommon.SubscriberStateTable(appl_db, "TABLE") |
| 111 | + sel.addSelectable(sst) |
| 112 | + thr = Thread(target=generator_SelectMemoryLeak) |
| 113 | + thr.daemon = True |
| 114 | + thr.start() |
| 115 | + time.sleep(5) |
| 116 | + for _ in xrange(N): |
| 117 | + state, c = sel.select(1000) |
| 118 | + diff = tracker.diff() |
| 119 | + cases = [] |
| 120 | + for name, count, _ in diff: |
| 121 | + if count >= N: |
| 122 | + cases.append("%s - %d objects for %d repeats" % (name, count, N)) |
| 123 | + thr.join() |
| 124 | + assert not cases |
0 commit comments