Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(9075)

Unified Diff: chrome/test/media_router/media_router_base_browsertest.h

Issue 595663002: Put chromoting isolate targets under chromoting_swarm_tests=1 GYP variable. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « chrome/test/media_router/e2e_tests.gyp ('k') | chrome/test/media_router/media_router_base_browsertest.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/test/media_router/media_router_base_browsertest.h
diff --git a/chrome/test/media_router/media_router_base_browsertest.h b/chrome/test/media_router/media_router_base_browsertest.h
new file mode 100644
index 0000000000000000000000000000000000000000..ef9670e00d218382dc3dec02a9f61496414337d1
--- /dev/null
+++ b/chrome/test/media_router/media_router_base_browsertest.h
@@ -0,0 +1,76 @@
+// Copyright 2015 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.
+
+#ifndef CHROME_TEST_MEDIA_ROUTER_MEDIA_ROUTER_BASE_BROWSERTEST_H_
+#define CHROME_TEST_MEDIA_ROUTER_MEDIA_ROUTER_BASE_BROWSERTEST_H_
+
+#include <string>
+
+#include "base/callback.h"
+#include "base/timer/timer.h"
+#include "chrome/browser/extensions/extension_apitest.h"
+#include "extensions/browser/process_manager_observer.h"
+
+namespace media_router {
+
+class MediaRouter;
+
+/**
+ * Base class for media router browser test.
+ *
+ * It provides the basic functions for integration and e2e browser tests,
+ * including install unpacked or packed extension at beginning of the test,
+ * uninstall the extension at the end of the test.
+ *
+ * This class accepts two flags to specify the location of MR extension:
+ * 1. "--extension-crx" flag to specify the packed extension location
+ * 2. "--extension-unpacked" flag to specify the unpacked extension location
+ * Only one of them should be passed when run browser tests.
+ */
+class MediaRouterBaseBrowserTest : public ExtensionBrowserTest,
+ public extensions::ProcessManagerObserver {
+ public:
+ MediaRouterBaseBrowserTest();
+ ~MediaRouterBaseBrowserTest() override;
+
+ // InProcessBrowserTest Overrides
+ void SetUp() override;
+ void TearDown() override;
+
+ protected:
+ // InProcessBrowserTest Overrides
+ void SetUpOnMainThread() override;
+ void TearDownOnMainThread() override;
+
+ void InstallAndEnableMRExtension();
+ void UninstallMRExtension();
+
+ virtual void ParseCommandLine();
+
+ // extensions::ProcessManagerObserver Overrides
+ void OnBackgroundHostCreated(extensions::ExtensionHost* host) override;
+
+ // Wait until get the successful callback or timeout.
+ void Wait(base::TimeDelta timeout,
+ base::TimeDelta interval,
+ const base::Callback<bool(void)>& callback);
+
+ // Wait for a specific time.
+ void Wait(base::TimeDelta timeout);
+
+ bool is_unpacked() const { return !extension_unpacked_.empty(); }
+
+ bool is_extension_host_created() const { return extension_host_created_; }
+
+ // These values are initialized via flags.
+ base::FilePath extension_crx_;
+ base::FilePath extension_unpacked_;
+
+ std::string extension_id_;
+ bool extension_host_created_;
+};
+
+} // namespace media_router
+
+#endif // CHROME_TEST_MEDIA_ROUTER_MEDIA_ROUTER_BASE_BROWSERTEST_H_
« no previous file with comments | « chrome/test/media_router/e2e_tests.gyp ('k') | chrome/test/media_router/media_router_base_browsertest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698