File: test_journal.py

package info (click to toggle)
pystemd 0.13.2-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,296 kB
  • sloc: python: 1,431; sh: 17; makefile: 8
file content (38 lines) | stat: -rw-r--r-- 1,053 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
#!/usr/bin/env python3
#
# Copyright (c) 2019-present, Facebook, Inc.
# All rights reserved.
#
# This source code is licensed under the license found in the LICENSE file in
# the root directory of this source tree.
#

from unittest import TestCase
from unittest.mock import ANY, call, patch

import pystemd.journal
from pystemd.utils import x2char_star


class TestJournalLog(TestCase):
    MESSAGE = "my message"
    PRIORITY = 101

    @patch("pystemd.journal.sendv")
    def test_msg(self, sendv):
        pystemd.journal.log(self.PRIORITY, self.MESSAGE)
        LOG_LINE = 24
        # ^^ that should be the line we called pystemd.journal.log.

        self.assertEqual(sendv.call_count, 1, "sendv should only be called once")

        sendv.call_args.assert_called_with(
            call(
                CODE_CONTEXT=ANY,
                CODE_LINE=LOG_LINE,
                CODE_FILE=__file__,
                MESSAGE=x2char_star(self.MESSAGE),
                PRIORITY=self.PRIORITY,
                CODE_FUNC="test_msg",
            )
        )