summaryrefslogtreecommitdiff
path: root/platform/android/src/test/render_test_runner.cpp
blob: c1ffbc81bff65f4d0b42089b7b6d4035e2f0d954 (plain)
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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104

#include "jni.hpp"
#include "logger.hpp"
#include <mbgl/render_test.hpp>
#include <android_native_app_glue.h>

#include <string>
#include <vector>

#include <mbgl/util/logging.hpp>

#include <android/log.h>


// Find a class, attempting to load the class if it's not found.
jclass LoadClass(JNIEnv* env, jobject activity_object, const char* class_name) {
    jclass class_object = env->FindClass(class_name);
    if (env->ExceptionCheck()) {
        env->ExceptionClear();
        // If the class isn't found it's possible NativeActivity is being used by
        // the application which means the class path is set to only load system
        // classes.  The following falls back to loading the class using the
        // Activity before retrieving a reference to it.
//        jclass activity_class = env->FindClass("android/app/NativeActivity");
        jclass activity_class = env->GetObjectClass(activity_object);
        jmethodID activity_get_class_loader = env->GetMethodID(
                activity_class, "getClassLoader", "()Ljava/lang/ClassLoader;");

        jobject class_loader_object =
                env->CallObjectMethod(activity_object, activity_get_class_loader);

        jclass class_loader_class = env->FindClass("java/lang/ClassLoader");
        jmethodID class_loader_load_class =
                env->GetMethodID(class_loader_class, "loadClass",
                                 "(Ljava/lang/String;)Ljava/lang/Class;");
        jstring class_name_object = env->NewStringUTF(class_name);

        class_object = static_cast<jclass>(env->CallObjectMethod(
                class_loader_object, class_loader_load_class, class_name_object));

        if (env->ExceptionCheck()) {
            env->ExceptionClear();
            class_object = nullptr;
        }
        env->DeleteLocalRef(class_name_object);
        env->DeleteLocalRef(class_loader_object);
    }
//    return class_object;
}




namespace mbgl {

    namespace {

        int severityToPriority(EventSeverity severity) {
                switch(severity) {
                    case EventSeverity::Debug:
                            return ANDROID_LOG_DEBUG;

                                case EventSeverity::Info:
                            return ANDROID_LOG_INFO;

                                case EventSeverity::Warning:
                            return ANDROID_LOG_WARN;

                               case EventSeverity::Error:
                            return ANDROID_LOG_ERROR;

                                default:
                            return ANDROID_LOG_VERBOSE;
                        }
            }

        } // namespace

    void Log::platformRecord(EventSeverity severity, const std::string &msg) {
         __android_log_print(severityToPriority(severity), "mbgl", "%s", msg.c_str());

    }

}


void android_main(struct android_app* app) {
    using FindClassFN = jclass (*)(JNIEnv*, const char*);
    mbgl::android::theJVM= app->activity->vm;
    JNIEnv* env;
    app->activity->vm->AttachCurrentThread(&env, NULL);
    // Logger

//    LoadClass(env, app->activity->clazz, mbgl::android::Logger::Name());
//    mbgl::android::Logger::registerNative(*env);
     std::vector<std::string> arguments = {"runner","-p", "/sdcard/render-test"};
     std::vector<char*> argv;
     for (const auto& arg : arguments) {
         argv.push_back((char*) arg.data());
     }
     argv.push_back(nullptr);
     mbgl::runRenderTests(argv.size() - 1, argv.data());
    app->activity->vm->DetachCurrentThread();
}