Project

General

Profile

« Previous | Next » 

Revision 4906

Added by daigle almost 16 years ago

Update load test code

View differences:

test/stress-test/insert-load-test.py
11 11
interval = int(sys.argv[3])
12 12
host = sys.argv[4]
13 13

  
14
# set debug=0 for no debugging.  Set it to 0 - 3 for increasing amounts of debug.
15
debug=0
14
# set debug_level=0 for no debugging.  Set it to 0 - 3 for increasing amounts of debug.
15
debug_level=2
16 16

  
17 17
run_time = str(time()).replace('.','')
18 18

  
19
output_file = "./insert-" + letter + ".out"
20
output_file = open(output_file, 'w')
19
output_file_name = "./insert-" + letter + ".out"
20
output_file = open(output_file_name, 'w')
21
output_file.close()
21 22

  
22 23
def debug (message):
24
	output_file = open(output_file_name, 'a')
23 25
	output_file.write(message + '\n')
26
	output_file.close()
24 27
	
25 28
def debug1 (message):
26
	if debug > 0:
29
	if debug_level > 0:
30
		output_file = open(output_file_name, 'a')
27 31
		output_file.write(message + '\n')
32
		output_file.close()
28 33

  
29 34
def debug2 (message):
30
	if debug > 1:
35
	if debug_level > 1:
36
		output_file = open(output_file_name, 'a')
31 37
		output_file.write(message + '\n')
38
		output_file.close()
32 39

  
33 40
def debug3 (message):
34
	if debug > 2:
41
	if debug_level > 2:
42
		output_file = open(output_file_name, 'a')
35 43
		output_file.write(message + '\n')
44
		output_file.close()
36 45

  
37
dictionary_file = open('./dictionary.txt', 'r')
46
dictionary_file_name = './dictionary-' + letter + '.txt'
47
dictionary_file = open(dictionary_file_name, 'r')
38 48

  
39 49
iter_count = 0
40 50

  
41 51
debug("************************************************** ")
42
debug("Starting squery-load-test for ") 
52
debug("Starting insert-load-test for ") 
43 53
debug("       letter: $letter ") 
44 54
debug("       iterations: $iterations ")
45 55
debug("       interval: $interval ")
56
debug("       host: $host ")
46 57
debug("************************************************** ")
47 58

  
48 59
# Initialize a metacat client connection and log in as test user
......
62 73
insert_template_file.close
63 74

  
64 75
for line in dictionary_file:
65
	if line.lower().startswith(letter.lower()):
66
		word = line.strip()
76
	word = line.strip()
67 77
		
68
		debug3("word: " + word)
69
		debug3("run time: " + run_time)
70
		debug3("iter count: " + str(iter_count))
71
		docid = word + run_time + '.' + str(iter_count) + '.1'
72
		doc = insert_template.replace("@!docid!@", docid)
73
		t1 = time()
78
	debug3("word: " + word)
79
	debug3("run time: " + run_time)
80
	debug3("iter count: " + str(iter_count))
81
	docid = word + run_time + '.' + str(iter_count) + '.1'
82
	doc = insert_template.replace("@!docid!@", docid)
83
	t1 = time()
74 84

  
75
		debug("[%s] -- Processing Insert" % (docid))
76
		response = mc.insert(docid, doc)
77
		t2 = time()
85
	debug("[%s] -- Processing Insert" % (docid))
86
	response = mc.insert(docid, doc)
87
	t2 = time()
78 88

  
79
		if (response.lower().find('<error>') == -1):
80
			debug("[%s] -- SUCCESS: elapsed time: %.5f seconds" % (docid, t2-t1))
81
		else:
82
			debug("[%s] -- ERROR: %s" % (docid, response))
89
	if (response.lower().find('<error>') == -1):
90
		debug("[%s] -- SUCCESS: elapsed time: %.5f seconds" % (docid, t2-t1))
91
	else:
92
		debug("[%s] -- ERROR: %s" % (docid, response))
83 93
		
84
		iter_count = iter_count + 1
85
		debug3("iter_count: %d, iterations: %d" % (iter_count, iterations))
86
		if iter_count >= iterations:		
87
			sys.exit()
94
	iter_count = iter_count + 1
95
	debug2("iter_count: %d, iterations: %d" % (iter_count, iterations))
96
	if iter_count >= iterations:		
97
		sys.exit()
88 98
			
89
		sleep(interval)
99
	sleep(interval)
90 100
	
91 101
dictionary_file.close()
92 102
output_file.close()
test/stress-test/metacat.py
71 71
            return False
72 72

  
73 73
    def read(self, docid, qformat="xml"):
74
        postdata = { 'action'   : 'read',
74
		postdata = { 'action'   : 'read',
75 75
                     'qformat'  : qformat,
76 76
                     'docid'    : docid }
77
        response = self.postRequest(postdata) 
78
        # if error node returned
79
        if response.find("<error>") != -1:
80
            return False
81
        else:
82
            return response
77
		response = self.postRequest(postdata) 
78
		# if error node returned
79
		return response
83 80

  
84 81

  
85 82
    def insert(self, docid, doctext):
test/stress-test/squery-load-test.py
11 11
interval = int(sys.argv[3])
12 12
host = sys.argv[4]
13 13

  
14
# set debug=0 for no debugging.  Set it to 0 - 3 for increasing amounts of debug.
15
debug=0
14
# set debug_level=0 for no debugging.  Set it to 0 - 3 for increasing amounts of debug.
15
debug_level=2
16 16

  
17
output_file = "./squery-" + letter + ".out"
18
output_file = open(output_file, 'w')
17
output_file_name = "./squery-" + letter + ".out"
18
output_file = open(output_file_name, 'w')
19
output_file.close()
19 20

  
20 21
def debug (message):
22
	output_file = open(output_file_name, 'a')
21 23
	output_file.write(message + '\n')
24
	output_file.close()
22 25
	
23 26
def debug1 (message):
24
	if debug > 0:
27
	if debug_level > 0:
28
		output_file = open(output_file_name, 'a')
25 29
		output_file.write(message + '\n')
30
		output_file.close()
26 31

  
27 32
def debug2 (message):
28
	if debug > 1:
33
	if debug_level > 1:
34
		output_file = open(output_file_name, 'a')
29 35
		output_file.write(message + '\n')
36
		output_file.close()
30 37

  
31 38
def debug3 (message):
32
	if debug > 2:
39
	if debug_level > 2:
40
		output_file = open(output_file_name, 'a')
33 41
		output_file.write(message + '\n')
42
		output_file.close()
34 43

  
35
dictionary_file = open('./dictionary.txt', 'r')
44
dictionary_file_name = './dictionary-' + letter + '.txt'
45
dictionary_file = open(dictionary_file_name, 'r')
36 46

  
37 47
iter_count = 0
38 48

  
......
41 51
debug("       letter: $letter ") 
42 52
debug("       iterations: $iterations ")
43 53
debug("       interval: $interval ")
54
debug("       host: $host ")
44 55
debug("************************************************** ")
45 56

  
46 57
mc = metacat.MetacatClient(host,'/knb/metacat')
......
50 61
query_template_file.close
51 62

  
52 63
for line in dictionary_file:
53
	if line.lower().startswith(letter.lower()):
54
		word = line.strip()
55
		debug("[%s] -- Processing Search" % (word))
56
		query = query_template.replace("@!search-word!@", word)
57
		t1 = time()
58
		response = mc.squery(query)
59
		t2 = time()
64
	word = line.strip()
65
	debug("[%s] -- Processing Search" % (word))
66
	query = query_template.replace("@!search-word!@", word)
67
	t1 = time()
68
	response = mc.squery(query)
69
	t2 = time()
60 70

  
61
		if response.find("<resultset>") != -1:
62
			debug("[%s] -- SUCCESS: elapsed time: %.5f seconds" % (word, t2-t1))
63
		else:
64
			debug("[%s] -- ERROR: " % (word), response)
71
	if response.find("<resultset>") != -1:
72
		debug("[%s] -- SUCCESS: elapsed time: %.5f seconds" % (word, t2-t1))
73
	else:
74
		debug("[%s] -- ERROR: " % (word), response)
65 75
			
66
		iter_count = iter_count + 1
67
		debug3("iter_count: %d, iterations: %d" % (iter_count, iterations))
68
		if iter_count >= iterations:		
69
			sys.exit()
76
	iter_count = iter_count + 1
77
	debug2("iter_count: %d, iterations: %d" % (iter_count, iterations))
78
	if iter_count >= iterations:		
79
		sys.exit()
70 80
			
71
		sleep(interval)
81
	sleep(interval)
72 82
	
73 83
dictionary_file.close()
74 84
output_file.close()
test/stress-test/read-load-test.py
1
#!/usr/bin/env python
2

  
3
import metacat
4
import sys
5

  
6
from time import time
7
from time import sleep
8

  
9
prefix = sys.argv[1]
10
iterations = int(sys.argv[2])
11
interval = int(sys.argv[3])
12
host = sys.argv[4]
13

  
14
# set debug_level=0 for no debugging.  Set it to 0 - 3 for increasing amounts of debug.
15
debug_level=2
16

  
17
run_time = str(time()).replace('.','')
18

  
19
output_file_name = "./read-" + prefix + ".out"
20
output_file = open(output_file_name, 'w')
21
output_file.close()
22

  
23
def debug (message):
24
	output_file = open(output_file_name, 'a')
25
	output_file.write(message + '\n')
26
	output_file.close()
27
	
28
def debug1 (message):
29
	if debug_level > 0:
30
		output_file = open(output_file_name, 'a')
31
		output_file.write(message + '\n')
32
		output_file.close()
33

  
34
def debug2 (message):
35
	if debug_level > 1:
36
		output_file = open(output_file_name, 'a')
37
		output_file.write(message + '\n')
38
		output_file.close()
39

  
40
def debug3 (message):
41
	if debug_level > 2:
42
		output_file = open(output_file_name, 'a')
43
		output_file.write(message + '\n')
44
		output_file.close()
45

  
46
iter_count = 0
47

  
48
debug("************************************************** ")
49
debug("Starting read-load-test for ") 
50
debug("       letter: $letter ") 
51
debug("       iterations: $iterations ")
52
debug("       interval: $interval ")
53
debug("       host: $host ")
54
debug("************************************************** ")
55

  
56
# Initialize a metacat client connection and log in as test user
57
t1 = time()
58
mc = metacat.MetacatClient(host,'/knb/metacat')
59
debug("[test] -- Processing Login")
60
response = mc.login('test', 'test', 'NCEAS')
61
t2 = time()
62

  
63
if (response):
64
	debug("[test] -- SUCCESS: elapsed time: %.5f seconds" %  (t2-t1))
65
else:
66
	debug("[test] -- ERROR: could not log in")
67

  
68
# Insert a document
69
insert_template_file = open('insert.xml.tmpl', 'r')
70
insert_template = insert_template_file.read()
71
insert_template_file.close
72

  
73
t1 = time()
74
docid = 'readtest-' + prefix + run_time + '.1.1'
75
doc = insert_template.replace("@!docid!@", docid)
76
debug("[%s] -- Processing Insert" % (docid))
77
response = mc.insert(docid, doc)
78
t2 = time()
79

  
80
if (response.lower().find('<error>') == -1):
81
	debug("[%s] -- SUCCESS: elapsed time: %.5f seconds" % (docid, t2-t1))
82
else:
83
	debug("[%s] -- ERROR: %s" % (docid, response))
84
t2 = time()
85

  
86
for i in range(1,iterations):
87
	t1 = time()
88

  
89
	debug("[%s] -- Processing Read" % (docid))
90
	response = mc.read(docid)
91
	t2 = time()
92

  
93
	if (response.lower().find('<error>') == -1):
94
		debug("[%s] -- SUCCESS: elapsed time: %.5f seconds" % (docid, t2-t1))
95
	else:
96
		debug("[%s] -- ERROR: %s" % (docid, response))
97
		
98
	iter_count = iter_count + 1
99
	debug2("iter_count: %d, iterations: %d" % (iter_count, iterations))
100
			
101
	sleep(interval)
102
	
103
output_file.close()
test/stress-test/load-test-driver.sh
6 6
# 3 April 2009 Michael Daigle (daigle@nceas.ucsb.edu)
7 7
#############################################################################
8 8

  
9
######################
9 10
# squery-load-test.py dictionary-letter iterations delay test-server 
11
######################
10 12

  
11 13
##### run squeries #####
12
./squery-load-test.py a 100 3 dev.nceas.ucsb.edu 2>&1 &
14
#./squery-load-test.py m 50 2 dev.nceas.ucsb.edu 2>&1 &
13 15

  
14 16
##### run squeries #####"
15
./squery-load-test.py b 100 3 dev.nceas.ucsb.edu 2>&1 &
17
#./squery-load-test.py n 50 2 dev.nceas.ucsb.edu 2>&1 &
16 18

  
17 19
##### run squeries #####
18
./squery-load-test.py c 100 3 dev.nceas.ucsb.edu 2>&1 &
20
#./squery-load-test.py o 50 2 dev.nceas.ucsb.edu 2>&1 &
19 21

  
20 22
##### run squeries #####
21
./squery-load-test.py d 100 3 dev.nceas.ucsb.edu 2>&1 &
23
#./squery-load-test.py p 50 2 dev.nceas.ucsb.edu 2>&1 &
22 24

  
25
######################
26
# insert-load-test.py dictionary-letter iterations delay test-server 
27
######################
23 28

  
29
##### run squeries #####
30
./insert-load-test.py a 50 2 dev.nceas.ucsb.edu 2>&1 &
31

  
32
##### run squeries #####"
33
./insert-load-test.py b 50 2 dev.nceas.ucsb.edu 2>&1 &
34

  
35
##### run squeries #####
36
./insert-load-test.py c 50 2 dev.nceas.ucsb.edu 2>&1 &
37

  
38
##### run squeries #####
39
./insert-load-test.py d 50 2 dev.nceas.ucsb.edu 2>&1 &
40

  
41
######################
42
# read-load-test.py prefix iterations delay test-server 
43
######################
44

  
45
##### run squeries #####
46
#./read-load-test.py a 300 3 dev.nceas.ucsb.edu 2>&1 &
47

  
48
##### run squeries #####"
49
#./read-load-test.py b 300 3 dev.nceas.ucsb.edu 2>&1 &
50

  
51
##### run squeries #####
52
#./read-load-test.py c 300 3 dev.nceas.ucsb.edu 2>&1 &
53

  
54
##### run squeries #####
55
#./read-load-test.py d 300 3 dev.nceas.ucsb.edu 2>&1 &
56

  
57
echo
58
echo "Running the following load tests:"
59
ps auxwww |grep load-test.py |grep -v grep
60

  
test/stress-test/generate-dictionaries.sh
1
#!/bin/bash
2

  
3
#############################################################################
4
# Create dictionary files of five letter words with every possible combination
5
# of letters.  Each file is named dictionary-X.txt where X is each letter of 
6
# the alphabet and the file holds all possible words that start with that
7
# letter.
8
#
9
# 6 April 2009 Michael Daigle (daigle@nceas.ucsb.edu)
10
#############################################################################
11

  
12
ltr=(a b c d e f g h i j k l m n o p q r s t u v w x y z)
13

  
14
> ./dictionary2.txt
15

  
16
for i in {0..25}
17
do
18
	for j in {0..25}
19
	do
20
		for k in {0..25}
21
		do
22
			for l in {0..25}
23
			do
24
				for m in {0..25}
25
				do
26
					echo ${ltr[$i]}${ltr[$j]}${ltr[$k]}${ltr[$l]}${ltr[$m]} >> ./dictionary-${ltr[$i]}.txt
27
				done
28
			done
29
		done
30
	done
31
done
0 32

  

Also available in: Unified diff