SpanTestCase.java 2.2 KB
Newer Older
P
pengys5 已提交
1
package org.skywalking.apm.trace;
2 3 4

import org.junit.Assert;
import org.junit.Test;
P
pengys5 已提交
5 6 7 8
import org.skywalking.apm.trace.tag.Tags;

import java.util.List;
import java.util.Map;
9 10 11 12 13 14 15 16 17

/**
 * Created by wusheng on 2017/2/18.
 */
public class SpanTestCase {
    @Test
    public void testConstructors() {
        Span span1 = new Span(0, "serviceA");
        Span span2 = new Span(2, span1, "serviceA");
wu-sheng's avatar
wu-sheng 已提交
18 19
        span2.setOperationName("serviceA-2");
        Assert.assertEquals("serviceA-2", span2.getOperationName());
20 21 22 23 24 25 26 27 28

        Assert.assertEquals(-1, span1.getParentSpanId());
        Assert.assertEquals(0, span2.getParentSpanId());
        Assert.assertTrue(span1.getStartTime() > 0);
        Assert.assertTrue(span2.getStartTime() > 0);
    }

    @Test
    public void testFinish() {
29
        TraceSegment owner = new TraceSegment("billing_app");
30 31 32 33 34 35 36 37 38 39 40 41 42

        Span span1 = new Span(0, "serviceA");

        Assert.assertTrue(span1.getEndTime() == 0);

        span1.finish(owner);
        Assert.assertEquals(span1, owner.getSpans().get(0));
        Assert.assertTrue(span1.getEndTime() > 0);
    }

    @Test
    public void testSetTag() {
        Span span1 = new Span(0, "serviceA");
wu-sheng's avatar
wu-sheng 已提交
43
        Tags.SPAN_LAYER.asHttp(span1);
44
        Tags.COMPONENT.set(span1, "Spring");
wu-sheng's avatar
wu-sheng 已提交
45
        Tags.PEER_HOST.set(span1, "127.0.0.1");
46
        Tags.ERROR.set(span1, true);
47 48 49
        Tags.STATUS_CODE.set(span1, 302);
        Tags.URL.set(span1, "http://127.0.0.1/serviceA");
        Tags.DB_STATEMENT.set(span1, "select * from users");
50 51

        Map<String, Object> tags = span1.getTags();
Z
zhangxin 已提交
52
        Assert.assertEquals(7, tags.size());
wu-sheng's avatar
wu-sheng 已提交
53
        Assert.assertTrue(Tags.SPAN_LAYER.isHttp(span1));
wu-sheng's avatar
wu-sheng 已提交
54
        Assert.assertEquals("127.0.0.1", Tags.PEER_HOST.get(span1));
55 56 57
        Assert.assertTrue(Tags.ERROR.get(span1));
    }

58
    @Test
59
    public void testLogException() {
60 61 62 63 64 65 66 67 68
        Span span1 = new Span(0, "serviceA");
        Exception exp = new Exception("exception msg");
        span1.log(exp);
        List<LogData> logs = span1.getLogs();

        Assert.assertEquals("java.lang.Exception", logs.get(0).getFields().get("error.kind"));
        Assert.assertEquals("exception msg", logs.get(0).getFields().get("message"));
        Assert.assertNotNull(logs.get(0).getFields().get("stack"));
    }
69
}