Index: chrome/common/extensions/manifest_tests/extension_manifests_service_worker_unittest.cc |
diff --git a/chrome/common/extensions/manifest_tests/extension_manifests_service_worker_unittest.cc b/chrome/common/extensions/manifest_tests/extension_manifests_service_worker_unittest.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..e1c6c3f2a8c5a5485bfccc530b8c37806c7422c9 |
--- /dev/null |
+++ b/chrome/common/extensions/manifest_tests/extension_manifests_service_worker_unittest.cc |
@@ -0,0 +1,127 @@ |
+// Copyright (c) 2012 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 "base/command_line.h" |
+#include "base/memory/scoped_ptr.h" |
+#include "base/test/values_test_util.h" |
+#include "base/values.h" |
+#include "chrome/common/extensions/features/feature_channel.h" |
+#include "chrome/common/extensions/manifest_tests/extension_manifest_test.h" |
+#include "content/public/common/content_switches.h" |
+#include "extensions/common/constants.h" |
+#include "extensions/common/error_utils.h" |
+#include "extensions/common/extension.h" |
+#include "extensions/common/manifest_constants.h" |
+#include "extensions/common/manifest_handlers/background_info.h" |
+#include "testing/gtest/include/gtest/gtest.h" |
+ |
+namespace extensions { |
+ |
+class ExtensionManifestServiceWorkerTest : public ExtensionManifestTest {}; |
+ |
+// Checks that a service_worker key is ignored without enable-service-worker |
+// switch. |
+TEST_F(ExtensionManifestServiceWorkerTest, ServiceWorkerCommandLineRequired) { |
+ const char* manifest_string = |
+ "{" |
+ " 'name': ''," |
+ " 'manifest_version': 2," |
+ " 'version': '1'," |
+ " 'app': {" |
+ " 'service_worker': {" |
+ " 'script': 'service_worker.js'" |
+ " }" |
+ " }" |
+ "}"; |
+ LoadAndExpectError(Manifest(base::test::ParseJsonDictionaryWithSingleQuotes( |
+ manifest_string).Pass(), |
+ ""), |
+ manifest_errors::kServiceWorkerRequiresFlag); |
+} |
+ |
+// Checks that an app manifest with a service_worker key but no script fails. |
+TEST_F(ExtensionManifestServiceWorkerTest, ServiceWorkerEmpty) { |
+ CommandLine::ForCurrentProcess()->AppendSwitch( |
Jeffrey Yasskin
2014/03/04 01:41:48
You have to remove the flag again at the end of th
scheib
2014/03/04 15:34:31
Wonderfully this is no longer the case, base::test
Jeffrey Yasskin
2014/03/04 17:29:15
Oh, great! I will forget that pitfall then. :)
|
+ switches::kEnableServiceWorker); |
+ const char* manifest_string = |
+ "{" |
+ " 'name': ''," |
+ " 'manifest_version': 2," |
+ " 'version': '1'," |
+ " 'app': {" |
+ " 'service_worker': {}" // No script specified. |
+ " }" |
+ "}"; |
+ LoadAndExpectError(Manifest(base::test::ParseJsonDictionaryWithSingleQuotes( |
+ manifest_string).Pass(), |
+ ""), |
+ manifest_errors::kBackgroundRequiredForPlatformApps); |
+ |
+ const char* manifest_string2 = |
+ "{" |
+ " 'name': ''," |
+ " 'manifest_version': 2," |
+ " 'version': '1'," |
+ " 'app': {" |
+ " 'service_worker': {" |
+ " 'script': ''" // Empty script. |
+ " }" |
+ " }" |
+ "}"; |
+ LoadAndExpectError(Manifest(base::test::ParseJsonDictionaryWithSingleQuotes( |
+ manifest_string2).Pass(), |
+ ""), |
+ manifest_errors::kBackgroundRequiredForPlatformApps); |
+} |
+ |
+// Checks that an app manifest with a single script is loaded. |
+TEST_F(ExtensionManifestServiceWorkerTest, ServiceWorkerScript) { |
+ CommandLine::ForCurrentProcess()->AppendSwitch( |
+ switches::kEnableServiceWorker); |
+ const char* manifest_string = |
+ "{" |
+ " 'name': ''," |
+ " 'manifest_version': 2," |
+ " 'version': '1'," |
+ " 'app': {" |
+ " 'service_worker': {" |
+ " 'script': 'service_worker.js'" |
+ " }" |
+ " }" |
+ "}"; |
+ scoped_refptr<Extension> extension(LoadAndExpectSuccess(Manifest( |
+ base::test::ParseJsonDictionaryWithSingleQuotes(manifest_string).Pass(), |
+ ""))); |
+ ASSERT_TRUE(extension.get()); |
+ EXPECT_EQ("service_worker.js", |
+ BackgroundInfo::GetServiceWorkerScript(extension.get())); |
+ |
+ EXPECT_TRUE(BackgroundInfo::HasServiceWorker(extension.get())); |
+} |
+ |
+// Checks that an app manifest with service worker and background script fails. |
+TEST_F(ExtensionManifestServiceWorkerTest, ServiceWorkerWithBackgroundScript) { |
+ CommandLine::ForCurrentProcess()->AppendSwitch( |
+ switches::kEnableServiceWorker); |
+ const char* manifest_string = |
+ "{" |
+ " 'name': ''," |
+ " 'manifest_version': 2," |
+ " 'version': '1'," |
+ " 'app': {" |
+ " 'service_worker': {" |
+ " 'script': 'service_worker.js'" |
+ " }," |
not at google - send to devlin
2014/03/03 19:56:07
when do you plan on adding the parsing logic for j
scheib
2014/03/03 20:25:46
After we have a hello world app working.
https://
not at google - send to devlin
2014/03/03 20:34:22
Why? It seems like minimal effort to add it right
scheib
2014/03/03 21:38:00
Discussed offline - it's not lots of work, but it'
|
+ " 'background': {" |
+ " 'scripts': [ 'background.js' ]" |
+ " }" |
+ " }" |
+ "}"; |
+ LoadAndExpectError(Manifest(base::test::ParseJsonDictionaryWithSingleQuotes( |
+ manifest_string).Pass(), |
+ ""), |
+ manifest_errors::kInvalidBackgroundCombination); |
+} |
+ |
+} // namespace extensions |