apache-ignite
41 строка · 1.6 Кб
1# Licensed to the Apache Software Foundation (ASF) under one or more
2# contributor license agreements. See the NOTICE file distributed with
3# this work for additional information regarding copyright ownership.
4# The ASF licenses this file to You under the Apache License, Version 2.0
5# (the "License"); you may not use this file except in compliance with
6# the License. You may obtain a copy of the License at
7#
8# http://www.apache.org/licenses/LICENSE-2.0
9#
10# Unless required by applicable law or agreed to in writing, software
11# distributed under the License is distributed on an "AS IS" BASIS,
12# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13# See the License for the specific language governing permissions and
14# limitations under the License.
15
16"""
17This module contains log utils.
18"""
19
20from contextlib import contextmanager21
22from ducktape.cluster.remoteaccount import LogMonitor23
24
25@contextmanager
26def monitor_log(node, log, from_the_beginning=False):27"""28Context manager that returns an object that helps you wait for events to
29occur in a log. This checks the size of the log at the beginning of the
30block and makes a helper object available with convenience methods for
31checking or waiting for a pattern to appear in the log. This will commonly
32be used to start a process, then wait for a log message indicating the
33process is in a ready state.
34
35See ``LogMonitor`` for more usage information.
36"""
37try:38offset = 0 if from_the_beginning else int(node.account.ssh_output("wc -c %s" % log).split()[0])39except Exception:40offset = 041yield LogMonitor(node.account, log, offset)42