summaryrefslogtreecommitdiff
path: root/indra/viewer_components/manager/tests/test_get_log_file_handle.py
blob: 5ea821acf7ccb2f9862390d96f23da854c0a169d (plain)
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
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
#!/usr/bin/env python

"""
@file   test_get_log_file_handle.py
@author coyot
@date   2016-06-08

$LicenseInfo:firstyear=2016&license=viewerlgpl$
Second Life Viewer Source Code
Copyright (C) 2016, Linden Research, Inc.

This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation;
version 2.1 of the License only.

This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Lesser General Public License for more details.

You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA

Linden Research, Inc., 945 Battery Street, San Francisco, CA  94111  USA
$/LicenseInfo$
"""

from nose.tools import *

import os
import shutil
import tempfile
import update_manager
import with_setup_args

def get_log_file_handle_setup():
    tmpdir1 = tempfile.mkdtemp(prefix = 'test1')
    tmpdir2 = tempfile.mkdtemp(prefix = 'test2')
    log_file_path = os.path.abspath(os.path.join(tmpdir1,"update_manager.log"))
    #not using tempfile because we want a particular filename
    open(log_file_path, 'w+').close

    return [tmpdir1,tmpdir2,log_file_path], {}

def get_log_file_handle_teardown(tmpdir1,tmpdir2,log_file_path):
    shutil.rmtree(tmpdir1, ignore_errors = True)
    shutil.rmtree(tmpdir2, ignore_errors = True)
    
@with_setup_args.with_setup_args(get_log_file_handle_setup, get_log_file_handle_teardown)
def test_existing_get_log_file_handle(tmpdir1,tmpdir2,log_file_path):
    handle = update_manager.get_log_file_handle(tmpdir1)
    if not handle:
        print "Failed to find existing log file"
        assert False
    elif not os.path.exists(os.path.abspath(log_file_path+".old")):
        print "Failed to rotate update manager log"
        assert False
    assert True
    
@with_setup_args.with_setup_args(get_log_file_handle_setup, get_log_file_handle_teardown)
def test_missing_get_log_file_handle(tmpdir1,tmpdir2,log_file_path):
    handle = update_manager.get_log_file_handle(tmpdir2)
    if not os.path.exists(log_file_path):
        print "Failed to touch new log file"
        assert False
    assert True