blob: 699fa4da3a93d17d983f23ee232b6226db067f51 [file] [log] [blame]
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -04001/*
2 * Copyright 2008, The Android Open Source Project
3 *
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions
6 * are met:
7 * * Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer.
9 * * Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution.
12 *
13 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS ``AS IS'' AND ANY
14 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR
17 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
18 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
19 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
20 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
21 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24 */
25
26#include "BackgroundPlugin.h"
27#include "android_npapi.h"
28
29#include <stdio.h>
30#include <sys/time.h>
31#include <time.h>
32#include <math.h>
33#include <string.h>
34
35extern NPNetscapeFuncs* browser;
36extern ANPBitmapInterfaceV0 gBitmapI;
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -040037extern ANPCanvasInterfaceV0 gCanvasI;
Derek Sollenbergerd049ec12009-08-07 11:26:44 -040038extern ANPLogInterfaceV0 gLogI;
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -040039extern ANPPaintInterfaceV0 gPaintI;
Derek Sollenbergerd049ec12009-08-07 11:26:44 -040040extern ANPSurfaceInterfaceV0 gSurfaceI;
Derek Sollenbergerb4a23912009-11-09 15:38:58 -050041extern ANPSystemInterfaceV0 gSystemI;
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -040042extern ANPTypefaceInterfaceV0 gTypefaceI;
Derek Sollenberger51cce582009-12-01 08:26:20 -050043extern ANPWindowInterfaceV0 gWindowI;
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -040044
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -040045#define ARRAY_COUNT(array) (sizeof(array) / sizeof(array[0]))
46
Derek Sollenberger0c763b62009-08-11 10:05:46 -040047static uint32_t getMSecs() {
48 struct timeval tv;
49 gettimeofday(&tv, NULL);
50 return (uint32_t) (tv.tv_sec * 1000 + tv.tv_usec / 1000 ); // microseconds to milliseconds
51}
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -040052
53///////////////////////////////////////////////////////////////////////////////
54
Derek Sollenberger08581f12009-09-08 18:36:29 -040055BackgroundPlugin::BackgroundPlugin(NPP inst) : SurfaceSubPlugin(inst) {
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -040056
Derek Sollenberger51cce582009-12-01 08:26:20 -050057 // initialize the java interface
58 m_javaInterface = NULL;
59
Derek Sollenbergerd049ec12009-08-07 11:26:44 -040060 // initialize the drawing surface
Derek Sollenberger08581f12009-09-08 18:36:29 -040061 m_surface = NULL;
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -040062
Derek Sollenbergerd049ec12009-08-07 11:26:44 -040063 //initialize bitmap transparency variables
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -040064 mFinishedStageOne = false;
65 mFinishedStageTwo = false;
66 mFinishedStageThree = false;
67
68 // test basic plugin functionality
69 test_logging(); // android logging
70 test_timers(); // plugin timers
71 test_bitmaps(); // android bitmaps
Derek Sollenbergerc356b9f2009-07-30 16:57:07 -040072 test_domAccess();
73 test_javascript();
Derek Sollenbergerb4a23912009-11-09 15:38:58 -050074 test_loadJavaClass();
Grace Kloba2c0f89a2009-12-09 00:13:05 -080075
76 //register for touch events
77 ANPEventFlags flags = kTouch_ANPEventFlag;
78 NPError err = browser->setvalue(inst, kAcceptEvents_ANPSetValue, &flags);
79 if (err != NPERR_NO_ERROR) {
80 gLogI.log(kError_ANPLogType, "Error selecting input events.");
81 }
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -040082}
83
Derek Sollenbergerb8947ee2009-10-05 14:40:18 -040084BackgroundPlugin::~BackgroundPlugin() {
Derek Sollenberger51cce582009-12-01 08:26:20 -050085 setJavaInterface(NULL);
Derek Sollenbergerb8947ee2009-10-05 14:40:18 -040086 surfaceDestroyed();
87}
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -040088
Derek Sollenberger21f39912009-07-09 09:19:39 -040089bool BackgroundPlugin::supportsDrawingModel(ANPDrawingModel model) {
Derek Sollenbergerd049ec12009-08-07 11:26:44 -040090 return (model == kSurface_ANPDrawingModel);
Derek Sollenberger21f39912009-07-09 09:19:39 -040091}
92
Derek Sollenberger08581f12009-09-08 18:36:29 -040093bool BackgroundPlugin::isFixedSurface() {
94 return false;
95}
96
Derek Sollenbergerb8947ee2009-10-05 14:40:18 -040097void BackgroundPlugin::surfaceCreated(jobject surface) {
98 m_surface = surface;
Derek Sollenberger08581f12009-09-08 18:36:29 -040099}
100
101void BackgroundPlugin::surfaceChanged(int format, int width, int height) {
102 drawPlugin(width, height);
103}
104
105void BackgroundPlugin::surfaceDestroyed() {
106 JNIEnv* env = NULL;
Derek Sollenbergerb8947ee2009-10-05 14:40:18 -0400107 if (m_surface && gVM->GetEnv((void**) &env, JNI_VERSION_1_4) == JNI_OK) {
Derek Sollenberger08581f12009-09-08 18:36:29 -0400108 env->DeleteGlobalRef(m_surface);
109 m_surface = NULL;
110 }
111}
112
Derek Sollenbergerd049ec12009-08-07 11:26:44 -0400113void BackgroundPlugin::drawPlugin(int surfaceWidth, int surfaceHeight) {
114
115 // get the plugin's dimensions according to the DOM
116 PluginObject *obj = (PluginObject*) inst()->pdata;
117 const int W = obj->window->width;
118 const int H = obj->window->height;
119
120 // compute the current zoom level
121 const float zoomFactorW = static_cast<float>(surfaceWidth) / W;
122 const float zoomFactorH = static_cast<float>(surfaceHeight) / H;
123
124 // check to make sure the zoom level is uniform
125 if (zoomFactorW + .01 < zoomFactorH && zoomFactorW - .01 > zoomFactorH)
Derek Sollenbergere62ce172009-11-30 11:52:06 -0500126 gLogI.log(kError_ANPLogType, " ------ %p zoom is out of sync (%f,%f)",
Derek Sollenbergerd049ec12009-08-07 11:26:44 -0400127 inst(), zoomFactorW, zoomFactorH);
128
129 // scale the variables based on the zoom level
130 const int fontSize = (int)(zoomFactorW * 16);
131 const int leftMargin = (int)(zoomFactorW * 10);
132
133 // lock the surface
134 ANPBitmap bitmap;
Derek Sollenberger08581f12009-09-08 18:36:29 -0400135 JNIEnv* env = NULL;
Derek Sollenbergerb8947ee2009-10-05 14:40:18 -0400136 if (!m_surface || gVM->GetEnv((void**) &env, JNI_VERSION_1_4) != JNI_OK ||
Derek Sollenberger08581f12009-09-08 18:36:29 -0400137 !gSurfaceI.lock(env, m_surface, &bitmap, NULL)) {
Derek Sollenbergere62ce172009-11-30 11:52:06 -0500138 gLogI.log(kError_ANPLogType, " ------ %p unable to lock the plugin", inst());
Derek Sollenbergerd049ec12009-08-07 11:26:44 -0400139 return;
140 }
141
142 // create a canvas
Derek Sollenbergerc0f26572009-07-16 11:38:02 -0400143 ANPCanvas* canvas = gCanvasI.newCanvas(&bitmap);
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -0400144 gCanvasI.drawColor(canvas, 0xFFFFFFFF);
145
Derek Sollenbergerd049ec12009-08-07 11:26:44 -0400146 ANPPaint* paint = gPaintI.newPaint();
147 gPaintI.setFlags(paint, gPaintI.getFlags(paint) | kAntiAlias_ANPPaintFlag);
148 gPaintI.setColor(paint, 0xFFFF0000);
149 gPaintI.setTextSize(paint, fontSize);
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -0400150
Derek Sollenbergerd049ec12009-08-07 11:26:44 -0400151 ANPTypeface* tf = gTypefaceI.createFromName("serif", kItalic_ANPTypefaceStyle);
152 gPaintI.setTypeface(paint, tf);
153 gTypefaceI.unref(tf);
154
155 ANPFontMetrics fm;
156 gPaintI.getFontMetrics(paint, &fm);
157
158 gPaintI.setColor(paint, 0xFF0000FF);
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -0400159 const char c[] = "This is a background plugin.";
Derek Sollenbergerd049ec12009-08-07 11:26:44 -0400160 gCanvasI.drawText(canvas, c, sizeof(c)-1, leftMargin, -fm.fTop, paint);
161
162 // clean up variables and unlock the surface
163 gPaintI.deletePaint(paint);
164 gCanvasI.deleteCanvas(canvas);
Derek Sollenberger08581f12009-09-08 18:36:29 -0400165 gSurfaceI.unlock(env, m_surface);
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -0400166}
167
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -0400168int16 BackgroundPlugin::handleEvent(const ANPEvent* evt) {
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -0400169 switch (evt->eventType) {
170 case kDraw_ANPEventType:
Derek Sollenbergere62ce172009-11-30 11:52:06 -0500171 gLogI.log(kError_ANPLogType, " ------ %p the plugin did not request draw events", inst());
Derek Sollenbergerd049ec12009-08-07 11:26:44 -0400172 break;
Derek Sollenbergerd049ec12009-08-07 11:26:44 -0400173 case kLifecycle_ANPEventType:
174 if (evt->data.lifecycle.action == kOnLoad_ANPLifecycleAction) {
Derek Sollenbergere62ce172009-11-30 11:52:06 -0500175 gLogI.log(kDebug_ANPLogType, " ------ %p the plugin received an onLoad event", inst());
Derek Sollenbergerd049ec12009-08-07 11:26:44 -0400176 return 1;
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -0400177 }
Derek Sollenbergerd049ec12009-08-07 11:26:44 -0400178 break;
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -0400179 case kTouch_ANPEventType:
Grace Kloba2c0f89a2009-12-09 00:13:05 -0800180 if (kDown_ANPTouchAction == evt->data.touch.action)
181 return kHandleLongPress_ANPTouchResult | kHandleDoubleTap_ANPTouchResult;
182 else if (kLongPress_ANPTouchAction == evt->data.touch.action)
183 browser->geturl(inst(), "javascript:alert('Detected long press event.')", 0);
184 else if (kDoubleTap_ANPTouchAction == evt->data.touch.action)
185 browser->geturl(inst(), "javascript:alert('Detected double tap event.')", 0);
Derek Sollenbergerd049ec12009-08-07 11:26:44 -0400186 break;
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -0400187 case kKey_ANPEventType:
Derek Sollenbergere62ce172009-11-30 11:52:06 -0500188 gLogI.log(kError_ANPLogType, " ------ %p the plugin did not request key events", inst());
Derek Sollenbergerd049ec12009-08-07 11:26:44 -0400189 break;
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -0400190 default:
191 break;
192 }
193 return 0; // unknown or unhandled event
194}
195
196///////////////////////////////////////////////////////////////////////////////
197// LOGGING TESTS
198///////////////////////////////////////////////////////////////////////////////
199
200
201void BackgroundPlugin::test_logging() {
202 NPP instance = this->inst();
203
204 //LOG_ERROR(instance, " ------ %p Testing Log Error", instance);
Derek Sollenbergere62ce172009-11-30 11:52:06 -0500205 gLogI.log(kError_ANPLogType, " ------ %p Testing Log Error", instance);
206 gLogI.log(kWarning_ANPLogType, " ------ %p Testing Log Warning", instance);
207 gLogI.log(kDebug_ANPLogType, " ------ %p Testing Log Debug", instance);
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -0400208}
209
210///////////////////////////////////////////////////////////////////////////////
211// TIMER TESTS
212///////////////////////////////////////////////////////////////////////////////
213
214#define TIMER_INTERVAL 50
215static void timer_oneshot(NPP instance, uint32 timerID);
216static void timer_repeat(NPP instance, uint32 timerID);
217static void timer_neverfires(NPP instance, uint32 timerID);
218static void timer_latency(NPP instance, uint32 timerID);
219
220void BackgroundPlugin::test_timers() {
221 NPP instance = this->inst();
222
223 //Setup the testing counters
224 mTimerRepeatCount = 5;
225 mTimerLatencyCount = 5;
226
227 // test for bogus timerID
228 browser->unscheduletimer(instance, 999999);
229 // test one-shot
230 browser->scheduletimer(instance, 100, false, timer_oneshot);
231 // test repeat
232 browser->scheduletimer(instance, 50, true, timer_repeat);
233 // test timer latency
234 browser->scheduletimer(instance, TIMER_INTERVAL, true, timer_latency);
235 mStartTime = mPrevTime = getMSecs();
236 // test unschedule immediately
237 uint32 id = browser->scheduletimer(instance, 100, false, timer_neverfires);
238 browser->unscheduletimer(instance, id);
239 // test double unschedule (should be no-op)
240 browser->unscheduletimer(instance, id);
241
242}
243
244static void timer_oneshot(NPP instance, uint32 timerID) {
Derek Sollenbergere62ce172009-11-30 11:52:06 -0500245 gLogI.log(kDebug_ANPLogType, "-------- oneshot timer\n");
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -0400246}
247
248static void timer_repeat(NPP instance, uint32 timerID) {
249 BackgroundPlugin *obj = ((BackgroundPlugin*) ((PluginObject*) instance->pdata)->activePlugin);
250
Derek Sollenbergere62ce172009-11-30 11:52:06 -0500251 gLogI.log(kDebug_ANPLogType, "-------- repeat timer %d\n",
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -0400252 obj->mTimerRepeatCount);
253 if (--obj->mTimerRepeatCount == 0) {
254 browser->unscheduletimer(instance, timerID);
255 }
256}
257
258static void timer_neverfires(NPP instance, uint32 timerID) {
Derek Sollenbergere62ce172009-11-30 11:52:06 -0500259 gLogI.log(kError_ANPLogType, "-------- timer_neverfires!!!\n");
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -0400260}
261
262static void timer_latency(NPP instance, uint32 timerID) {
263 BackgroundPlugin *obj = ((BackgroundPlugin*) ((PluginObject*) instance->pdata)->activePlugin);
264
265 obj->mTimerLatencyCurrentCount += 1;
266
267 uint32_t now = getMSecs();
268 uint32_t interval = now - obj->mPrevTime;
269 uint32_t dur = now - obj->mStartTime;
270 uint32_t expectedDur = obj->mTimerLatencyCurrentCount * TIMER_INTERVAL;
271 int32_t drift = dur - expectedDur;
272 int32_t avgDrift = drift / obj->mTimerLatencyCurrentCount;
273
274 obj->mPrevTime = now;
275
Derek Sollenbergere62ce172009-11-30 11:52:06 -0500276 gLogI.log(kDebug_ANPLogType,
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -0400277 "-------- latency test: [%3d] interval %d expected %d, total %d expected %d, drift %d avg %d\n",
278 obj->mTimerLatencyCurrentCount, interval, TIMER_INTERVAL, dur,
279 expectedDur, drift, avgDrift);
280
281 if (--obj->mTimerLatencyCount == 0) {
282 browser->unscheduletimer(instance, timerID);
283 }
284}
285
286///////////////////////////////////////////////////////////////////////////////
287// BITMAP TESTS
288///////////////////////////////////////////////////////////////////////////////
289
290static void test_formats(NPP instance);
291
292void BackgroundPlugin::test_bitmaps() {
293 test_formats(this->inst());
294}
295
296static void test_formats(NPP instance) {
297
298 // TODO pull names from enum in npapi instead of hardcoding them
299 static const struct {
300 ANPBitmapFormat fFormat;
301 const char* fName;
302 } gRecs[] = {
303 { kUnknown_ANPBitmapFormat, "unknown" },
304 { kRGBA_8888_ANPBitmapFormat, "8888" },
305 { kRGB_565_ANPBitmapFormat, "565" },
306 };
307
308 ANPPixelPacking packing;
309 for (size_t i = 0; i < ARRAY_COUNT(gRecs); i++) {
310 if (gBitmapI.getPixelPacking(gRecs[i].fFormat, &packing)) {
Derek Sollenbergere62ce172009-11-30 11:52:06 -0500311 gLogI.log(kDebug_ANPLogType,
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -0400312 "pixel format [%d] %s has packing ARGB [%d %d] [%d %d] [%d %d] [%d %d]\n",
313 gRecs[i].fFormat, gRecs[i].fName,
314 packing.AShift, packing.ABits,
315 packing.RShift, packing.RBits,
316 packing.GShift, packing.GBits,
317 packing.BShift, packing.BBits);
318 } else {
Derek Sollenbergere62ce172009-11-30 11:52:06 -0500319 gLogI.log(kDebug_ANPLogType,
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -0400320 "pixel format [%d] %s has no packing\n",
321 gRecs[i].fFormat, gRecs[i].fName);
322 }
323 }
324}
325
326void BackgroundPlugin::test_bitmap_transparency(const ANPEvent* evt) {
327 NPP instance = this->inst();
328
329 // check default & set transparent
330 if (!mFinishedStageOne) {
331
Derek Sollenbergere62ce172009-11-30 11:52:06 -0500332 gLogI.log(kDebug_ANPLogType, "BEGIN: testing bitmap transparency");
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -0400333
334 //check to make sure it is not transparent
335 if (evt->data.draw.data.bitmap.format == kRGBA_8888_ANPBitmapFormat) {
Derek Sollenbergere62ce172009-11-30 11:52:06 -0500336 gLogI.log(kError_ANPLogType, "bitmap default format is transparent");
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -0400337 }
338
339 //make it transparent (any non-null value will set it to true)
340 bool value = true;
341 NPError err = browser->setvalue(instance, NPPVpluginTransparentBool, &value);
342 if (err != NPERR_NO_ERROR) {
Derek Sollenbergere62ce172009-11-30 11:52:06 -0500343 gLogI.log(kError_ANPLogType, "Error setting transparency.");
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -0400344 }
345
346 mFinishedStageOne = true;
347 browser->invalidaterect(instance, NULL);
348 }
349 // check transparent & set opaque
350 else if (!mFinishedStageTwo) {
351
352 //check to make sure it is transparent
353 if (evt->data.draw.data.bitmap.format != kRGBA_8888_ANPBitmapFormat) {
Derek Sollenbergere62ce172009-11-30 11:52:06 -0500354 gLogI.log(kError_ANPLogType, "bitmap did not change to transparent format");
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -0400355 }
356
357 //make it opaque
358 NPError err = browser->setvalue(instance, NPPVpluginTransparentBool, NULL);
359 if (err != NPERR_NO_ERROR) {
Derek Sollenbergere62ce172009-11-30 11:52:06 -0500360 gLogI.log(kError_ANPLogType, "Error setting transparency.");
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -0400361 }
362
363 mFinishedStageTwo = true;
364 }
365 // check opaque
366 else if (!mFinishedStageThree) {
367
368 //check to make sure it is not transparent
369 if (evt->data.draw.data.bitmap.format == kRGBA_8888_ANPBitmapFormat) {
Derek Sollenbergere62ce172009-11-30 11:52:06 -0500370 gLogI.log(kError_ANPLogType, "bitmap default format is transparent");
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -0400371 }
372
Derek Sollenbergere62ce172009-11-30 11:52:06 -0500373 gLogI.log(kDebug_ANPLogType, "END: testing bitmap transparency");
Derek Sollenbergerd7ebf272009-06-18 11:19:41 -0400374
375 mFinishedStageThree = true;
376 }
377}
Derek Sollenbergerc356b9f2009-07-30 16:57:07 -0400378
379///////////////////////////////////////////////////////////////////////////////
380// DOM TESTS
381///////////////////////////////////////////////////////////////////////////////
382
383void BackgroundPlugin::test_domAccess() {
384 NPP instance = this->inst();
385
Derek Sollenbergere62ce172009-11-30 11:52:06 -0500386 gLogI.log(kDebug_ANPLogType, " ------ %p Testing DOM Access", instance);
Derek Sollenbergerc356b9f2009-07-30 16:57:07 -0400387
388 // Get the plugin's DOM object
389 NPObject* windowObject = NULL;
390 browser->getvalue(instance, NPNVWindowNPObject, &windowObject);
391
392 if (!windowObject)
Derek Sollenbergere62ce172009-11-30 11:52:06 -0500393 gLogI.log(kError_ANPLogType, " ------ %p Unable to retrieve DOM Window", instance);
Derek Sollenbergerc356b9f2009-07-30 16:57:07 -0400394
395 // Retrieve a property from the plugin's DOM object
396 NPIdentifier topIdentifier = browser->getstringidentifier("top");
397 NPVariant topObjectVariant;
398 browser->getproperty(instance, windowObject, topIdentifier, &topObjectVariant);
399
400 if (topObjectVariant.type != NPVariantType_Object)
Derek Sollenbergere62ce172009-11-30 11:52:06 -0500401 gLogI.log(kError_ANPLogType, " ------ %p Invalid Variant type for DOM Property: %d,%d", instance, topObjectVariant.type, NPVariantType_Object);
Derek Sollenbergerc356b9f2009-07-30 16:57:07 -0400402}
403
404
405///////////////////////////////////////////////////////////////////////////////
406// JAVASCRIPT TESTS
407///////////////////////////////////////////////////////////////////////////////
408
409
410void BackgroundPlugin::test_javascript() {
411 NPP instance = this->inst();
412
Derek Sollenbergere62ce172009-11-30 11:52:06 -0500413 gLogI.log(kDebug_ANPLogType, " ------ %p Testing JavaScript Access", instance);
Derek Sollenbergerc356b9f2009-07-30 16:57:07 -0400414
415 // Get the plugin's DOM object
416 NPObject* windowObject = NULL;
417 browser->getvalue(instance, NPNVWindowNPObject, &windowObject);
418
419 if (!windowObject)
Derek Sollenbergere62ce172009-11-30 11:52:06 -0500420 gLogI.log(kError_ANPLogType, " ------ %p Unable to retrieve DOM Window", instance);
Derek Sollenbergerc356b9f2009-07-30 16:57:07 -0400421
422 // create a string (JS code) that is stored in memory allocated by the browser
423 const char* jsString = "1200 + 34";
424 void* stringMem = browser->memalloc(strlen(jsString));
425 memcpy(stringMem, jsString, strlen(jsString));
426
427 // execute the javascript in the plugin's DOM object
428 NPString script = { (char*)stringMem, strlen(jsString) };
429 NPVariant scriptVariant;
430 if (!browser->evaluate(instance, windowObject, &script, &scriptVariant))
Derek Sollenbergere62ce172009-11-30 11:52:06 -0500431 gLogI.log(kError_ANPLogType, " ------ %p Unable to eval the JS.", instance);
Derek Sollenbergerc356b9f2009-07-30 16:57:07 -0400432
433 if (scriptVariant.type == NPVariantType_Int32) {
434 if (scriptVariant.value.intValue != 1234)
Derek Sollenbergere62ce172009-11-30 11:52:06 -0500435 gLogI.log(kError_ANPLogType, " ------ %p Invalid Value for JS Return: %d,1234", instance, scriptVariant.value.intValue);
Derek Sollenbergerc356b9f2009-07-30 16:57:07 -0400436 } else {
Derek Sollenbergere62ce172009-11-30 11:52:06 -0500437 gLogI.log(kError_ANPLogType, " ------ %p Invalid Variant type for JS Return: %d,%d", instance, scriptVariant.type, NPVariantType_Int32);
Derek Sollenbergerc356b9f2009-07-30 16:57:07 -0400438 }
439
440 // free the memory allocated within the browser
441 browser->memfree(stringMem);
442}
Derek Sollenbergerb4a23912009-11-09 15:38:58 -0500443
444///////////////////////////////////////////////////////////////////////////////
445// Load Java Classes Tests
446///////////////////////////////////////////////////////////////////////////////
447
448void BackgroundPlugin::test_loadJavaClass() {
449
450 JNIEnv* env = NULL;
451 if (gVM->GetEnv((void**) &env, JNI_VERSION_1_4) != JNI_OK) {
Derek Sollenbergere62ce172009-11-30 11:52:06 -0500452 gLogI.log(kError_ANPLogType, " ---- LoadJavaTest: failed to get env");
Derek Sollenbergerb4a23912009-11-09 15:38:58 -0500453 return;
454 }
455
456 const char* className = "com.android.sampleplugin.BackgroundTest";
457 jclass backgroundClass = gSystemI.loadJavaClass(inst(), className);
458
459 if(!backgroundClass) {
Derek Sollenbergere62ce172009-11-30 11:52:06 -0500460 gLogI.log(kError_ANPLogType, " ---- LoadJavaTest: failed to load class");
Derek Sollenbergerb4a23912009-11-09 15:38:58 -0500461 return;
462 }
463
464 jmethodID constructor = env->GetMethodID(backgroundClass, "<init>", "()V");
465 jmethodID addMethod = env->GetMethodID(backgroundClass, "addInt", "(II)I");
466 jobject backgroundObject = env->NewObject(backgroundClass, constructor);
467
468 if(!backgroundObject) {
Derek Sollenbergere62ce172009-11-30 11:52:06 -0500469 gLogI.log(kError_ANPLogType, " ---- LoadJavaTest: failed to construct object");
Derek Sollenbergerb4a23912009-11-09 15:38:58 -0500470 return;
471 }
472
473 jint result = env->CallIntMethod(backgroundObject, addMethod, 2, 2);
474
475 if (result != 4) {
Derek Sollenbergere62ce172009-11-30 11:52:06 -0500476 gLogI.log(kError_ANPLogType, " ---- LoadJavaTest: invalid result (%d != 4)", result);
Derek Sollenbergerb4a23912009-11-09 15:38:58 -0500477 }
478}