Ejemplo n.º 1
0
 def test_functional_reader_extract(self):
     engine_obj = EngineEmul()
     obj = FuncJTLReader(RESOURCES_DIR + "/jmeter/jtl/crash_trace.jtl",
                         engine_obj,
                         logging.getLogger(''))
     samples = list(obj.read(last_pass=True))
     self.assertNotEqual(len(samples), 0)
Ejemplo n.º 2
0
 def test_functional_reader_artifact_files(self):
     engine_obj = EngineEmul()
     obj = FuncJTLReader(RESOURCES_DIR + "/jmeter/jtl/trace.jtl",
                         engine_obj,
                         logging.getLogger(''))
     samples = list(obj.read(last_pass=True))
     self.assertEqual(1, len(samples))
     self.assertTrue(os.path.exists(os.path.join(engine_obj.artifacts_dir, "sample-responseBody.bin")))
Ejemplo n.º 3
0
 def test_functional_reader_extras_empty_body(self):
     engine_obj = EngineEmul()
     obj = FuncJTLReader(RESOURCES_DIR + "/jmeter/jtl/cookies.jtl",
                         engine_obj,
                         logging.getLogger(''))
     samples = list(obj.read(last_pass=True))
     self.assertEqual(2, len(samples))
     sample = samples[1]
     self.assertIsNotNone(sample.extras)
     self.assertEqual(sample.extras["requestCookies"], {'hello': 'world', 'visited': 'yes'})
Ejemplo n.º 4
0
 def test_functional_reader_failed(self):
     engine_obj = EngineEmul()
     obj = FuncJTLReader(RESOURCES_DIR + "/jmeter/jtl/standard-errors.jtl",
                         engine_obj,
                         logging.getLogger(''))
     samples = list(obj.read(last_pass=True))
     self.assertEqual(185, len(samples))
     first = samples[0]
     self.assertEqual(first.test_case, "http://blazedemo.com/some-more-or-less-long-label")
     self.assertEqual(first.test_suite, "JMeter")
     self.assertEqual(first.status, "FAILED")
     self.assertEqual(first.start_time, 1430825787)
     self.assertEqual(first.duration, 0.011)
     self.assertEqual(first.error_msg, "The operation lasted too long")
Ejemplo n.º 5
0
 def test_functional_reader_broken(self):
     engine_obj = EngineEmul()
     obj = FuncJTLReader(RESOURCES_DIR + "/jmeter/jtl/standard-errors.jtl",
                         engine_obj,
                         logging.getLogger(''))
     samples = list(obj.read(last_pass=True))
     self.assertEqual(185, len(samples))
     sample = samples[8]
     self.assertEqual(sample.test_case, "http://blazedemo.com/some-more-or-less-long-label")
     self.assertEqual(sample.test_suite, "JMeter")
     self.assertEqual(sample.status, "BROKEN")
     self.assertEqual(sample.start_time, 1430825788)
     self.assertEqual(sample.duration, 0.01)
     self.assertEqual(sample.error_msg, "Non HTTP response message: Read timed out")
     self.assertTrue(sample.error_trace.startswith("java.net.SocketTimeoutException: Read timed out"))
Ejemplo n.º 6
0
 def test_functional_reader_pass(self):
     engine_obj = EngineEmul()
     obj = FuncJTLReader(RESOURCES_DIR + "/jmeter/jtl/resource-errors-no-fail.jtl",
                         engine_obj,
                         logging.getLogger(''))
     samples = list(obj.read(last_pass=True))
     self.assertEqual(2, len(samples))
     first = samples[0]
     self.assertEqual(first.test_case, "HTTP Request")
     self.assertEqual(first.test_suite, "JMeter")
     self.assertEqual(first.status, "PASSED")
     self.assertEqual(first.start_time, 1440764640)
     self.assertEqual(first.duration, 0.419)
     self.assertEqual(first.error_msg, "")
     self.assertEqual(first.error_trace, "")
Ejemplo n.º 7
0
 def test_functional_reader_extras_assertions(self):
     engine_obj = EngineEmul()
     obj = FuncJTLReader(RESOURCES_DIR + "/jmeter/jtl/trace.jtl",
                         engine_obj,
                         logging.getLogger(''))
     samples = list(obj.read(last_pass=True))
     self.assertEqual(1, len(samples))
     sample = samples[0]
     self.assertIsNotNone(sample.extras)
     self.assertEqual(len(sample.extras["assertions"]), 2)
     first, second = sample.extras["assertions"]
     self.assertEqual(first, {"name": 'Passing Assertion',
                              "isFailed": False,
                              "errorMessage": ""})
     self.assertEqual(second, {"name": 'Failing Assertion',
                               "isFailed": True,
                               "errorMessage": "Test failed: text expected to contain /something/"})
Ejemplo n.º 8
0
 def test_functional_reader_extras(self):
     engine_obj = EngineEmul()
     obj = FuncJTLReader(RESOURCES_DIR + "/jmeter/jtl/trace.jtl",
                         engine_obj,
                         logging.getLogger(''))
     samples = list(obj.read(last_pass=True))
     self.assertEqual(1, len(samples))
     sample = samples[0]
     self.assertIsNotNone(sample.extras)
     fields = [
         'assertions', 'connectTime', 'latency', 'responseTime',
         'requestBody', 'requestBodySize', 'requestCookies', 'requestCookiesRaw', 'requestCookiesSize',
         'requestHeaders', 'requestMethod', 'requestSize', 'requestURI',
         'responseBody', 'responseBodySize', 'responseCode', 'responseHeaders',
         'responseMessage', 'responseSize',
         "threadId", "threadGroup",
     ]
     for field in set(fields) - set(FuncJTLReader.FILE_EXTRACTED_FIELDS):
         self.assertIn(field, sample.extras)
     self.assertEqual(sample.extras["requestURI"], "http://blazedemo.com/")
     self.assertEqual(sample.extras["requestMethod"], "GET")
Ejemplo n.º 9
0
 def configure(self, jtl_file):
     engine = EngineEmul()
     self.obj = FuncJTLReader(jtl_file, engine, logging.getLogger(''))
Ejemplo n.º 10
0
class TestFuncJTLReader(BZTestCase):
    def setUp(self):
        super(TestFuncJTLReader, self).setUp()
        self.obj = None

    def configure(self, jtl_file):
        engine = EngineEmul()
        self.obj = FuncJTLReader(jtl_file, engine, logging.getLogger(''))

    def tearDown(self):
        close_reader_file(self.obj)
        super(TestFuncJTLReader, self).tearDown()

    def test_functional_reader_pass(self):
        self.configure(RESOURCES_DIR + "/jmeter/jtl/resource-errors-no-fail.jtl")
        samples = list(self.obj.read(last_pass=True))
        self.assertEqual(2, len(samples))
        first = samples[0]
        self.assertEqual(first.test_case, "HTTP Request")
        self.assertEqual(first.test_suite, "JMeter")
        self.assertEqual(first.status, "PASSED")
        self.assertEqual(first.start_time, 1440764640)
        self.assertEqual(first.duration, 0.419)
        self.assertEqual(first.error_msg, "")
        self.assertEqual(first.error_trace, "")

    def test_functional_reader_failed(self):
        self.configure(RESOURCES_DIR + "/jmeter/jtl/standard-errors.jtl")
        samples = list(self.obj.read(last_pass=True))
        self.assertEqual(185, len(samples))
        first = samples[0]
        self.assertEqual(first.test_case, "http://blazedemo.com/some-more-or-less-long-label")
        self.assertEqual(first.test_suite, "JMeter")
        self.assertEqual(first.status, "FAILED")
        self.assertEqual(first.start_time, 1430825787)
        self.assertEqual(first.duration, 0.011)
        self.assertEqual(first.error_msg, "The operation lasted too long")

    def test_functional_reader_broken(self):
        self.configure(RESOURCES_DIR + "/jmeter/jtl/standard-errors.jtl")
        samples = list(self.obj.read(last_pass=True))
        self.assertEqual(185, len(samples))
        sample = samples[8]
        self.assertEqual(sample.test_case, "http://blazedemo.com/some-more-or-less-long-label")
        self.assertEqual(sample.test_suite, "JMeter")
        self.assertEqual(sample.status, "BROKEN")
        self.assertEqual(sample.start_time, 1430825788)
        self.assertEqual(sample.duration, 0.01)
        self.assertEqual(sample.error_msg, "Non HTTP response message: Read timed out")
        self.assertTrue(sample.error_trace.startswith("java.net.SocketTimeoutException: Read timed out"))

    def test_functional_reader_extras(self):
        self.configure(RESOURCES_DIR + "/jmeter/jtl/trace.jtl")
        samples = list(self.obj.read(last_pass=True))
        self.assertEqual(1, len(samples))
        sample = samples[0]
        self.assertIsNotNone(sample.extras)
        fields = [
            'assertions', 'connectTime', 'latency', 'responseTime',
            'requestBody', 'requestBodySize', 'requestCookies', 'requestCookiesRaw', 'requestCookiesSize',
            'requestHeaders', 'requestMethod', 'requestSize', 'requestURI',
            'responseBody', 'responseBodySize', 'responseCode', 'responseHeaders',
            'responseMessage', 'responseSize',
            "threadId", "threadGroup"]
        for field in set(fields) - set(FuncJTLReader.FILE_EXTRACTED_FIELDS):
            self.assertIn(field, sample.extras)
        self.assertEqual(sample.extras["requestURI"], "http://blazedemo.com/")
        self.assertEqual(sample.extras["requestMethod"], "GET")

    def test_functional_reader_artifact_files(self):
        self.configure(RESOURCES_DIR + "/jmeter/jtl/trace.jtl")
        samples = list(self.obj.read(last_pass=True))
        self.assertEqual(1, len(samples))
        sample_path = os.path.join(self.obj.engine.artifacts_dir, "sample-responseBody.bin")
        self.assertTrue(os.path.exists(sample_path))

    def test_functional_reader_extras_assertions(self):
        self.configure(RESOURCES_DIR + "/jmeter/jtl/trace.jtl")
        samples = list(self.obj.read(last_pass=True))
        self.assertEqual(1, len(samples))
        sample = samples[0]
        self.assertIsNotNone(sample.extras)
        self.assertEqual(len(sample.extras["assertions"]), 2)
        first, second = sample.extras["assertions"]
        self.assertEqual(first, {"name": 'Passing Assertion',
                                 "isFailed": False,
                                 "errorMessage": ""})
        self.assertEqual(second, {"name": 'Failing Assertion',
                                  "isFailed": True,
                                  "errorMessage": "Test failed: text expected to contain /something/"})

    def test_functional_reader_extras_empty_body(self):
        self.configure(RESOURCES_DIR + "/jmeter/jtl/cookies.jtl")
        samples = list(self.obj.read(last_pass=True))
        self.assertEqual(2, len(samples))
        sample = samples[1]
        self.assertIsNotNone(sample.extras)
        self.assertEqual(sample.extras["requestCookies"], {'hello': 'world', 'visited': 'yes'})

    def test_functional_reader_extract(self):
        self.configure(RESOURCES_DIR + "/jmeter/jtl/crash_trace.jtl")
        samples = list(self.obj.read(last_pass=True))
        self.assertNotEqual(len(samples), 0)

    def test_unicode_errors(self):
        self.configure(RESOURCES_DIR + "/jmeter/jtl/unicode-reqs.jtl")
        samples = list(self.obj.read(last_pass=True))

        origin_string = u'чсмтчомтчжом'
        for sample in samples:
            self.assertEqual(sample.test_case, origin_string)
Ejemplo n.º 11
0
 def configure(self, jtl_file):
     engine = EngineEmul()
     self.obj = FuncJTLReader(jtl_file, engine, logging.getLogger(''))
Ejemplo n.º 12
0
class TestFuncJTLReader(BZTestCase):
    def setUp(self):
        super(TestFuncJTLReader, self).setUp()
        self.obj = None

    def configure(self, jtl_file):
        engine = EngineEmul()
        self.obj = FuncJTLReader(jtl_file, engine, logging.getLogger(''))

    def tearDown(self):
        close_reader_file(self.obj)
        super(TestFuncJTLReader, self).tearDown()

    def test_functional_reader_pass(self):
        self.configure(RESOURCES_DIR +
                       "/jmeter/jtl/resource-errors-no-fail.jtl")
        samples = list(self.obj.read())
        self.assertEqual(2, len(samples))
        first = samples[0]
        self.assertEqual(first.test_case, "HTTP Request")
        self.assertEqual(first.test_suite, "JMeter")
        self.assertEqual(first.status, "PASSED")
        self.assertEqual(first.start_time, 1440764640)
        self.assertEqual(first.duration, 0.419)
        self.assertEqual(first.error_msg, "")
        self.assertEqual(first.error_trace, "")

    def test_functional_reader_failed(self):
        self.configure(RESOURCES_DIR + "/jmeter/jtl/standard-errors.jtl")
        samples = list(self.obj.read())
        self.assertEqual(185, len(samples))
        first = samples[0]
        self.assertEqual(first.test_case,
                         "http://blazedemo.com/some-more-or-less-long-label")
        self.assertEqual(first.test_suite, "JMeter")
        self.assertEqual(first.status, "FAILED")
        self.assertEqual(first.start_time, 1430825787)
        self.assertEqual(first.duration, 0.011)
        self.assertEqual(first.error_msg, "The operation lasted too long")

    def test_functional_reader_broken(self):
        self.configure(RESOURCES_DIR + "/jmeter/jtl/standard-errors.jtl")
        samples = list(self.obj.read())
        self.assertEqual(185, len(samples))
        sample = samples[8]
        self.assertEqual(sample.test_case,
                         "http://blazedemo.com/some-more-or-less-long-label")
        self.assertEqual(sample.test_suite, "JMeter")
        self.assertEqual(sample.status, "BROKEN")
        self.assertEqual(sample.start_time, 1430825788)
        self.assertEqual(sample.duration, 0.01)
        self.assertEqual(sample.error_msg,
                         "Non HTTP response message: Read timed out")
        self.assertTrue(
            sample.error_trace.startswith(
                "java.net.SocketTimeoutException: Read timed out"))

    def test_functional_reader_extras(self):
        self.configure(RESOURCES_DIR + "/jmeter/jtl/trace.jtl")
        samples = list(self.obj.read())
        self.assertEqual(1, len(samples))
        sample = samples[0]
        self.assertIsNotNone(sample.extras)
        fields = [
            'assertions', 'connectTime', 'latency', 'responseTime',
            'requestBody', 'requestBodySize', 'requestCookies',
            'requestCookiesRaw', 'requestCookiesSize', 'requestHeaders',
            'requestMethod', 'requestSize', 'requestURI', 'responseBody',
            'responseBodySize', 'responseCode', 'responseHeaders',
            'responseMessage', 'responseSize', "threadId", "threadGroup"
        ]
        for field in set(fields) - set(FuncJTLReader.FILE_EXTRACTED_FIELDS):
            self.assertIn(field, sample.extras)
        self.assertEqual(sample.extras["requestURI"], "http://blazedemo.com/")
        self.assertEqual(sample.extras["requestMethod"], "GET")

    def test_functional_reader_artifact_files(self):
        self.configure(RESOURCES_DIR + "/jmeter/jtl/trace.jtl")
        samples = list(self.obj.read())
        self.assertEqual(1, len(samples))
        sample_path = os.path.join(self.obj.engine.artifacts_dir,
                                   "sample-responseBody.bin")
        self.assertTrue(os.path.exists(sample_path))

    def test_functional_reader_extras_assertions(self):
        self.configure(RESOURCES_DIR + "/jmeter/jtl/trace.jtl")
        samples = list(self.obj.read())
        self.assertEqual(1, len(samples))
        sample = samples[0]
        self.assertIsNotNone(sample.extras)
        self.assertEqual(len(sample.extras["assertions"]), 2)
        first, second = sample.extras["assertions"]
        self.assertEqual(first, {
            "name": 'Passing Assertion',
            "isFailed": False,
            "errorMessage": ""
        })
        self.assertEqual(
            second, {
                "name": 'Failing Assertion',
                "isFailed": True,
                "errorMessage":
                "Test failed: text expected to contain /something/"
            })

    def test_functional_reader_extras_empty_body(self):
        self.configure(RESOURCES_DIR + "/jmeter/jtl/cookies.jtl")
        samples = list(self.obj.read())
        self.assertEqual(2, len(samples))
        sample = samples[1]
        self.assertIsNotNone(sample.extras)
        self.assertEqual(sample.extras["requestCookies"], {
            'hello': 'world',
            'visited': 'yes'
        })

    def test_functional_reader_extract(self):
        self.configure(RESOURCES_DIR + "/jmeter/jtl/crash_trace.jtl")
        samples = list(self.obj.read())
        self.assertNotEqual(len(samples), 0)

    def test_unicode_errors(self):
        self.configure(RESOURCES_DIR + "/jmeter/jtl/unicode-reqs.jtl")
        samples = list(self.obj.read())

        origin_string = u'чсмтчомтчжом'
        for sample in samples:
            self.assertEqual(sample.test_case, origin_string)
Ejemplo n.º 13
0
 def configure(self, jtl_file):
     engine = EngineEmul()
     self.obj = FuncJTLReader(jtl_file, engine, ROOT_LOGGER)
Ejemplo n.º 14
0
 def configure(self, jtl_file):
     engine = EngineEmul()
     self.obj = FuncJTLReader(jtl_file, engine, ROOT_LOGGER)