Chromium Code Reviews| 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..b6aaff2acdaabec6e515a055c17bb3d0dd55ed85 |
| --- /dev/null |
| +++ b/chrome/common/extensions/manifest_tests/extension_manifests_service_worker_unittest.cc |
| @@ -0,0 +1,131 @@ |
| +// 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) { |
| + CHECK(!CommandLine::ForCurrentProcess()->HasSwitch( |
| + ::switches::kEnableServiceWorker)); |
| + 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) { |
| + CHECK(!CommandLine::ForCurrentProcess()->HasSwitch( |
| + ::switches::kEnableServiceWorker)); |
| + CommandLine::ForCurrentProcess()->AppendSwitch( |
| + 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) { |
| + CHECK(!CommandLine::ForCurrentProcess()->HasSwitch( |
| + ::switches::kEnableServiceWorker)); |
| + 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()))); |
|
Jeffrey Yasskin
2014/03/04 17:29:16
You probably don't need a .Pass() here, since the
scheib
2014/03/04 17:51:24
Done.
|
| + 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) { |
| + CHECK(!CommandLine::ForCurrentProcess()->HasSwitch( |
| + ::switches::kEnableServiceWorker)); |
| + CommandLine::ForCurrentProcess()->AppendSwitch( |
| + switches::kEnableServiceWorker); |
| + const char* manifest_string = |
| + "{" |
| + " 'name': ''," |
| + " 'manifest_version': 2," |
| + " 'version': '1'," |
| + " 'app': {" |
| + " 'service_worker': {" |
| + " 'script': 'service_worker.js'" |
| + " }," |
| + " 'background': {" |
| + " 'scripts': [ 'background.js' ]" |
| + " }" |
| + " }" |
| + "}"; |
| + LoadAndExpectError(Manifest(base::test::ParseJsonDictionaryWithSingleQuotes( |
| + manifest_string).Pass()), |
| + manifest_errors::kInvalidBackgroundCombination); |
| +} |
| + |
| +} // namespace extensions |