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
|
#!/usr/bin/env python
# $LicenseInfo:firstyear=2016&license=internal$
#
# Copyright (c) 2016, Linden Research, Inc.
#
# The following source code is PROPRIETARY AND CONFIDENTIAL. Use of
# this source code is governed by the Linden Lab Source Code Disclosure
# Agreement ("Agreement") previously entered between you and Linden
# Lab. By accessing, using, copying, modifying or distributing this
# software, you acknowledge that you have been informed of your
# obligations under the Agreement and agree to abide by those obligations.
#
# ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO
# WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY,
# COMPLETENESS OR PERFORMANCE.
# $/LicenseInfo$
"""
@file test_get_log_file_handle.py
@author coyot
@date 2016-06-08
"""
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
|