Total Complexity | 3 |
Total Lines | 40 |
Duplicated Lines | 0 % |
Changes | 0 |
1 | #!/usr/bin/env python |
||
2 | # |
||
3 | # Glances - An eye on your system |
||
4 | # |
||
5 | # SPDX-FileCopyrightText: 2024 Nicolas Hennion <[email protected]> |
||
6 | # |
||
7 | # SPDX-License-Identifier: LGPL-3.0-only |
||
8 | # |
||
9 | |||
10 | """Glances unitary tests suite for Glances memory leak.""" |
||
11 | |||
12 | import time |
||
13 | import tracemalloc |
||
14 | |||
15 | |||
16 | def test_memoryleak_no_history(glances_stats_no_history, logger): |
||
17 | """ |
||
18 | Test Glances memory leak. |
||
19 | """ |
||
20 | tracemalloc.start() |
||
21 | # First iterations just to init the stats and fill the memory |
||
22 | logger.info('Please wait during memory leak test initialisation') |
||
23 | iteration = 3 |
||
24 | for _ in range(iteration): |
||
25 | glances_stats_no_history.update() |
||
26 | time.sleep(1) |
||
27 | |||
28 | # Then iteration to measure memory leak |
||
29 | logger.info('Please wait during memory leak test') |
||
30 | iteration = 10 |
||
31 | snapshot_begin = tracemalloc.take_snapshot() |
||
32 | for _ in range(iteration): |
||
33 | glances_stats_no_history.update() |
||
34 | time.sleep(1) |
||
35 | snapshot_end = tracemalloc.take_snapshot() |
||
36 | snapshot_diff = snapshot_end.compare_to(snapshot_begin, 'filename') |
||
37 | memory_leak = sum([s.size_diff for s in snapshot_diff]) // iteration |
||
38 | logger.info(f'Memory consume per iteration: {memory_leak} bytes') |
||
39 | assert memory_leak < 15000, f'Memory leak: {memory_leak} bytes' |
||
40 |