Index: webkit/glue/plugins/test/plugin_thread_async_call_test.cc |
=================================================================== |
--- webkit/glue/plugins/test/plugin_thread_async_call_test.cc (revision 0) |
+++ webkit/glue/plugins/test/plugin_thread_async_call_test.cc (revision 0) |
@@ -0,0 +1,92 @@ |
+// Copyright (c) 2006-2008 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "webkit/glue/plugins/test/plugin_thread_async_call_test.h" |
+#include "webkit/glue/plugins/test/plugin_client.h" |
+ |
+namespace NPAPIClient { |
+ |
+namespace { |
+ |
+// There are two plugin instances in this test. The long lived instance is used |
+// for reporting errors and signalling test completion. The short lived one is |
+// used to verify that async callbacks are not invoked after NPP_Destroy. |
+PluginThreadAsyncCallTest* g_short_lived_instance; |
+PluginThreadAsyncCallTest* g_long_lived_instance; |
+ |
+void OnCallSucceededHelper(void* data) { |
+ static_cast<PluginThreadAsyncCallTest*>(data)->OnCallSucceeded(); |
+} |
+ |
+void OnCallFailed(void* data) { |
+ g_long_lived_instance->SetError("Async callback invoked after NPP_Destroy"); |
+} |
+ |
+void OnCallCompletedHelper(void* data) { |
+ static_cast<PluginThreadAsyncCallTest*>(data)->OnCallCompleted(); |
+} |
+} |
+ |
+PluginThreadAsyncCallTest::PluginThreadAsyncCallTest( |
+ NPP id, NPNetscapeFuncs *host_functions) |
+ : PluginTest(id, host_functions) { |
+} |
+ |
+NPError PluginThreadAsyncCallTest::New( |
+ uint16 mode, int16 argc, const char* argn[], const char* argv[], |
+ NPSavedData* saved) { |
+ NPError error = PluginTest::New(mode, argc, argn, argv, saved); |
+ if (error != NPERR_NO_ERROR) |
+ return error; |
+ |
+ // Determine whether this is the short lived instance. |
+ for (int i = 0; i < argc; ++i) { |
+ if (base::strcasecmp(argn[i], "short_lived") == 0) { |
+ if (base::strcasecmp(argv[i], "true") == 0) { |
+ g_short_lived_instance = this; |
+ } else { |
+ g_long_lived_instance = this; |
+ } |
+ } |
+ } |
+ |
+ // Schedule an async call that will succeed. |
+ if (this == g_short_lived_instance) { |
+ HostFunctions()->pluginthreadasynccall(id(), OnCallSucceededHelper, this); |
+ } |
+ |
+ return NPERR_NO_ERROR; |
+} |
+ |
+void PluginThreadAsyncCallTest::OnCallSucceeded() { |
+ // Delete the short lived instance. |
+ NPIdentifier delete_id = HostFunctions()->getstringidentifier( |
+ "deleteShortLivedInstance"); |
+ |
+ NPObject *window_obj = NULL; |
+ HostFunctions()->getvalue(id(), NPNVWindowNPObject, &window_obj); |
+ |
+ NPVariant result; |
+ HostFunctions()->invoke(id(), window_obj, delete_id, NULL, 0, &result); |
+} |
+ |
+NPError PluginThreadAsyncCallTest::Destroy() { |
+ if (this == g_short_lived_instance) { |
+ // Schedule an async call that should not be called. |
+ HostFunctions()->pluginthreadasynccall(id(), OnCallFailed, NULL); |
+ |
+ // Schedule an async call to end the test using the long lived instance. |
+ HostFunctions()->pluginthreadasynccall(g_long_lived_instance->id(), |
+ OnCallCompletedHelper, |
+ g_long_lived_instance); |
+ } |
+ |
+ return NPERR_NO_ERROR; |
+} |
+ |
+void PluginThreadAsyncCallTest::OnCallCompleted() { |
+ SignalTestCompleted(); |
+} |
+ |
+} // namespace NPAPIClient |