diff options
| author | 2011-06-05 21:26:30 +0200 | |
|---|---|---|
| committer | 2011-06-05 21:26:30 +0200 | |
| commit | b4f11103dc031df77117ee4cbb08f8e87305d20a (patch) | |
| tree | a193e0c98f32e88a2ab09c95c6e1ad1740ff687a /module/common | |
| parent | youtube - file extension based on fmt (diff) | |
| download | pyload-b4f11103dc031df77117ee4cbb08f8e87305d20a.tar.xz | |
api tester
Diffstat (limited to 'module/common')
| -rw-r--r-- | module/common/APIExerciser.py | 197 | ||||
| -rw-r--r-- | module/common/JsEngine.py | 146 | ||||
| -rw-r--r-- | module/common/__init__.py | 2 | 
3 files changed, 345 insertions, 0 deletions
| diff --git a/module/common/APIExerciser.py b/module/common/APIExerciser.py new file mode 100644 index 000000000..f645f12df --- /dev/null +++ b/module/common/APIExerciser.py @@ -0,0 +1,197 @@ +# -*- coding: utf-8 -*- + +import string +from threading import Thread +from random import choice, random, sample, randint +from time import time, sleep + +from traceback import print_exc, format_exc + +from module.remote.thriftbackend.ThriftClient import ThriftClient + +def createURLs(): +    """ create some urls, some may fail """ +    urls = [] +    for x in range(0, randint(20, 100)): +        name = "DEBUG_API" +        if randint(0, 5) == 5: +            name = "" #this link will fail + +        urls.append(name + "".join(sample(string.ascii_letters, randint(10, 20)))) + +    return urls + +AVOID = (0,3,8) + +class APIExerciser(Thread): +    """ tests api randomly """ + +    def __init__(self, core): +        Thread.__init__(self) +        self.setDaemon(True) +        self.core = core +        self.methods = core.server_methods +        self.count = 0 #number of methods +        self.time = time() + +        self.start() + +    def run(self): +        out = open("error.log", "ab") +        #core errors are not logged of course +        out.write("\n" + "Starting\n") +        out.flush() + +        while True: +            try: +                self.testAPI() +            except Exception: +                print_exc() +                out.write(format_exc() + 2 * "\n") +                out.flush() + +            if not self.count % 100: +                print "Tested %s api calls" % self.count +            if not self.count % 1000: +                out.write("Tested %s api calls\n" % self.count) +                out.flush() + + +                #sleep(random() / 500) + +    def testAPI(self): +        m = ["status_downloads", "status_server", "add_package", "get_package_data", "get_file_data", "del_links", +             "del_packages", +             "get_queue", "get_collector", "get_queue_info", "get_collector_info", "is_captcha_waiting"] + +        method = choice(m) +        #print "Testing:", method + +        if hasattr(self, method): +            res = getattr(self, method)() +        else: +            res = getattr(self.methods, method)() + +        self.count += 1 + +        #print res + +    def add_package(self): +        name = "".join(sample(string.ascii_letters, 10)) +        urls = createURLs() + +        self.methods.add_package(name, urls, 1) + + +    def del_links(self): +        info = self.methods.get_queue() +        if not info: return + +        pid = choice(info.keys()) +        pack = info[pid] +        links = pack["links"] +        #filter links which are not queued, finished or failed +        fids = filter(lambda x: links[x]["status"] not in AVOID, links.keys()) + +        if len(fids): +            fids = sample(fids, randint(1, max(len(fids) / 2, 1))) +            self.methods.del_links(fids) + + +    def del_packages(self): +        info = self.methods.get_queue_info() +        if not info: return + +        pids = info.keys() +        if len(pids): +            pids = sample(pids, randint(1, max(len(pids) / 2, 1))) +            filtered = [] + +            for p in pids: +                info = self.methods.get_package_data(p) +                append = True +                for link in info["links"].itervalues(): +                    if link["status"] not in AVOID: +                        append = False +                        break + +                if append: filtered.append(p) + +            self.methods.del_packages(filtered) + +    def get_file_data(self): +        info = self.methods.get_queue() +        if info: +            p = info[choice(info.keys())] +            if p["links"]: +                self.methods.get_file_data(choice(p["links"].keys())) + +    def get_package_data(self): +        info = self.methods.get_queue_info() +        if info: +            self.methods.get_package_data(choice(info.keys())) + + +class ThriftExerciser(APIExerciser): +    def __init__(self, core): +        self.thrift = ThriftClient() +        self.thrift.login("user", "pw") + +        APIExerciser.__init__(self, core) + +    def testAPI(self): +        m = ["statusDownloads", "statusServer", "addPackage", "getPackageData", "getFileData", "deleteFiles", +             "deletePackages", +             "getQueue", "getCollector", "getQueueData", "getCollectorData", "isCaptchaWaiting"] + +        method = choice(m) +        #print "Testing:", method + +        if hasattr(self, method): +            res = getattr(self, method)() +        else: +            res = getattr(self.thrift, method)() + +        self.count += 1 + +        #print res + +    def addPackage(self): +        name = "".join(sample(string.ascii_letters, 10)) +        urls = createURLs() + +        self.thrift.addPackage(name, urls, 0) + + +    def deleteFiles(self): +        info = self.thrift.getQueueData() +        if not info: return + +        pack = choice(info) +        fids = pack.links + +        if len(fids): +            fids = [f.fid for f in sample(fids, randint(1, max(len(fids) / 2, 1)))] +            self.thrift.deleteFiles(fids) + + +    def deletePackages(self): +        info = self.thrift.getQueue() +        if not info: return + +        pids = [p.pid for p in info] +        if len(pids): +            pids = sample(pids, randint(1, max(len(pids) / 2, 1))) +            self.thrift.deletePackages(pids) + +    def getFileData(self): +        info = self.thrift.getQueueData() +        if info: +            p = choice(info) +            if p.links: +                self.thrift.getFileData(choice(p.links).fid) + +    def getPackageData(self): +        info = self.thrift.getQueue() +        if info: +            self.thrift.getPackageData(choice(info).pid)
\ No newline at end of file diff --git a/module/common/JsEngine.py b/module/common/JsEngine.py new file mode 100644 index 000000000..0b451c9dd --- /dev/null +++ b/module/common/JsEngine.py @@ -0,0 +1,146 @@ +#!/usr/bin/env python +# -*- coding: utf-8 -*- +""" +    This program is free software; you can redistribute it and/or modify +    it under the terms of the GNU General Public License as published by +    the Free Software Foundation; either version 3 of the License, +    or (at your option) any later version. + +    This program 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 General Public License for more details. + +    You should have received a copy of the GNU General Public License +    along with this program; if not, see <http://www.gnu.org/licenses/>. + +    @author: RaNaN +""" + +from imp import find_module +from os.path import join, exists + +ENGINE = "" + +try: +    find_module("spidermonkey") +    ENGINE = "spidermonkey" +except: +    pass + +if not ENGINE: +    try: +        find_module("PyV8") +        ENGINE = "pyv8" +    except: +        pass + +if not ENGINE: +    try: +        import subprocess + +        subprocess.Popen(["js", "-v"], bufsize=-1, stdout=subprocess.PIPE, stderr=subprocess.PIPE).communicate() +        p = subprocess.Popen(["js", "-e", "print(23+19)"], stdout=subprocess.PIPE, stderr=subprocess.PIPE) +        out, err = p.communicate() +        #integrity check +        if out.strip() == "42": +            ENGINE = "js" +    except: +        pass + + +if not ENGINE or ENGINE: +    try: +        path = "" #path where to find rhino + +        if exists("/usr/share/java/js.jar"): +            path = "/usr/share/java/js.jar" +        elif exists("js.jar"): +            path = "js.jar" +        elif exists(join(pypath, "js.jar")): #may raises an exception, but js.jar wasnt found anyway +            path = join(pypath, "js.jar") + +        if not path: +            raise Exception + +        import subprocess + +        p = subprocess.Popen(["java", "-cp", path, "org.mozilla.javascript.tools.shell.Main", "-e", "print(23+19)"], stdout=subprocess.PIPE, stderr=subprocess.PIPE) +        out, err = p.communicate() +        #integrity check +        if out.strip() == "42": +            ENGINE = "rhino" +    except: +        pass + +class JsEngine(): +    def __init__(self): +        self.engine = ENGINE +        self.init = False + +    def __nonzero__(self): +        return False if not ENGINE else True + +    def eval(self, script): +        if not self.init: +            if ENGINE == "spidermonkey": +                import spidermonkey +                global spidermonkey + +            elif ENGINE == "pyv8": +                import PyV8 +                global PyV8 +                 +            self.init = True + +        if not ENGINE: +            raise Exception("No JS Engine") +        elif ENGINE == "spidermonkey": +            return self.eval_spidermonkey(script) +        elif ENGINE == "pyv8": +            return self.eval_pyv8(script) +        elif ENGINE == "js": +            return self.eval_js(script) +        elif ENGINE == "rhino": +            return self.eval_rhino(script) + + +    def eval_spidermonkey(self, script): +        rt = spidermonkey.Runtime() +        cx = rt.new_context() +        return cx.execute(script) + +    def eval_pyv8(self, script): +        rt = PyV8.JSContext() +        rt.enter() +        return rt.eval(script) + +    def eval_js(self, script): +        script = "print(eval('%s'))" % script.replace("'", '"') +        p = subprocess.Popen(["js", "-e", script], stdout=subprocess.PIPE, stderr=subprocess.STDOUT, bufsize=-1) +        out, err = p.communicate() +        res = out.strip() +        return res + +    def eval_rhino(self, script): +        script = "print(eval('%s'))" % script.replace("'", '"') +        p = subprocess.Popen(["java", "-cp", path, "org.mozilla.javascript.tools.shell.Main", "-e", script], stdout=subprocess.PIPE, stderr=subprocess.STDOUT, bufsize=-1) +        out, err = p.communicate() +        res = out.strip() +        return res + +    def error(self): +        return _("No js engine detected, please install either Spidermonkey, ossp-js, pyv8 or rhino") + +if __name__ == "__main__": +    js = JsEngine() +    import subprocess +    import spidermonkey +    #import PyV8 + +    test = '"a"+"b"' + +    print js.eval_js(test) +    print js.eval_spidermonkey(test) +    print js.eval_rhino(test) +    print js.eval_pyv8(test)
\ No newline at end of file diff --git a/module/common/__init__.py b/module/common/__init__.py new file mode 100644 index 000000000..de6d13128 --- /dev/null +++ b/module/common/__init__.py @@ -0,0 +1,2 @@ +__author__ = 'christian' +  
\ No newline at end of file | 
