Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "base/memory/scoped_ptr.h" | |
| 6 #include "chrome/browser/extensions/api/notification_provider/notification_provi der_api.h" | 5 #include "chrome/browser/extensions/api/notification_provider/notification_provi der_api.h" |
| 7 #include "chrome/browser/extensions/chrome_extension_function.h" | 6 #include "chrome/browser/extensions/chrome_extension_function.h" |
| 8 #include "chrome/browser/extensions/extension_apitest.h" | 7 #include "chrome/browser/extensions/extension_apitest.h" |
| 9 #include "chrome/browser/profiles/profile.h" | 8 #include "chrome/browser/profiles/profile.h" |
| 10 #include "chrome/common/extensions/api/notification_provider.h" | 9 #include "chrome/common/extensions/api/notification_provider.h" |
| 11 | 10 |
| 12 typedef ExtensionApiTest NotificationProviderApiTest; | 11 typedef ExtensionApiTest NotificationProviderApiTest; |
| 13 | 12 |
| 13 namespace { | |
| 14 | |
| 15 void CreateNotificationOptionsForTest( | |
|
Pete Williamson
2014/08/04 20:30:45
Great job refactoring this! This is exactly the k
liyanhou
2014/08/04 23:24:16
Thank you!
| |
| 16 extensions::api::notifications::NotificationOptions* options) { | |
| 17 options->type = extensions::api::notifications::ParseTemplateType("basic"); | |
| 18 options->icon_url = scoped_ptr<std::string>(new std::string("icon.png")); | |
| 19 options->title = scoped_ptr<std::string>(new std::string("Title")); | |
| 20 options->message = | |
| 21 scoped_ptr<std::string>(new std::string("Here goes the message")); | |
| 22 return; | |
| 23 } | |
| 24 | |
| 25 } // namespace | |
| 26 | |
| 14 IN_PROC_BROWSER_TEST_F(NotificationProviderApiTest, Events) { | 27 IN_PROC_BROWSER_TEST_F(NotificationProviderApiTest, Events) { |
| 15 std::string sender_id1 = "SenderId1"; | 28 std::string sender_id1 = "SenderId1"; |
| 16 std::string notification_id1 = "NotificationId1"; | 29 std::string notification_id1 = "NotificationId1"; |
| 17 | 30 |
| 18 extensions::api::notifications::NotificationOptions options; | 31 scoped_ptr<extensions::api::notifications::NotificationOptions> options( |
| 19 options.type = extensions::api::notifications::ParseTemplateType("basic"); | 32 new extensions::api::notifications::NotificationOptions()); |
| 20 options.icon_url = scoped_ptr<std::string>(new std::string("icon.png")); | 33 CreateNotificationOptionsForTest(options.get()); |
| 21 options.title = scoped_ptr<std::string>(new std::string("Title")); | |
| 22 options.message = | |
| 23 scoped_ptr<std::string>(new std::string("Here goes the message")); | |
| 24 | 34 |
| 25 ResultCatcher catcher; | 35 ResultCatcher catcher; |
| 26 catcher.RestrictToProfile(browser()->profile()); | 36 catcher.RestrictToProfile(browser()->profile()); |
| 27 | 37 |
| 28 // Test notification provider extension | 38 // Test notification provider extension |
| 29 const extensions::Extension* extension = | 39 const extensions::Extension* extension = |
| 30 LoadExtension(test_data_dir_.AppendASCII("notification_provider/events")); | 40 LoadExtension(test_data_dir_.AppendASCII("notification_provider/events")); |
| 31 ASSERT_TRUE(extension); | 41 ASSERT_TRUE(extension); |
| 32 | 42 |
| 33 scoped_ptr<extensions::NotificationProviderEventRouter> event_router( | 43 extensions::NotificationProviderEventRouter* event_router = |
|
Pete Williamson
2014/08/04 20:30:45
Why remove the use of scoped_ptr here? If we did
liyanhou
2014/08/04 23:24:16
Done. Sorry that was a mistake.
| |
| 34 new extensions::NotificationProviderEventRouter(browser()->profile())); | 44 new extensions::NotificationProviderEventRouter(browser()->profile()); |
| 35 | 45 |
| 36 event_router->CreateNotification( | 46 event_router->CreateNotification( |
| 37 extension->id(), sender_id1, notification_id1, options); | 47 extension->id(), sender_id1, notification_id1, *options.get()); |
| 38 event_router->UpdateNotification( | 48 event_router->UpdateNotification( |
| 39 extension->id(), sender_id1, notification_id1, options); | 49 extension->id(), sender_id1, notification_id1, *options.release()); |
| 40 event_router->ClearNotification( | 50 event_router->ClearNotification( |
| 41 extension->id(), sender_id1, notification_id1); | 51 extension->id(), sender_id1, notification_id1); |
| 42 | 52 |
| 43 EXPECT_TRUE(catcher.GetNextResult()) << catcher.message(); | 53 EXPECT_TRUE(catcher.GetNextResult()) << catcher.message(); |
| 44 } | 54 } |
| 55 | |
| 56 IN_PROC_BROWSER_TEST_F(NotificationProviderApiTest, TestBasicUsage) { | |
| 57 // set up content of a notification | |
| 58 std::string sender_id1 = "SenderId"; | |
| 59 std::string notification_id1 = "NotificationId"; | |
| 60 | |
| 61 scoped_ptr<extensions::api::notifications::NotificationOptions> options( | |
| 62 new extensions::api::notifications::NotificationOptions()); | |
| 63 CreateNotificationOptionsForTest(options.get()); | |
| 64 | |
| 65 ResultCatcher catcher; | |
| 66 catcher.RestrictToProfile(browser()->profile()); | |
| 67 | |
| 68 // Test notification provider extension | |
| 69 const extensions::Extension* extension = LoadExtension( | |
|
Pete Williamson
2014/08/04 20:30:46
Do we ever free this memory? Might be good to use
liyanhou
2014/08/04 23:24:16
Do we need to free this memory if it's not new'd?
| |
| 70 test_data_dir_.AppendASCII("notification_provider/basic_usage")); | |
| 71 ASSERT_TRUE(extension); | |
| 72 | |
| 73 extensions::NotificationProviderEventRouter* event_router = | |
|
Pete Williamson
2014/08/04 20:30:45
ccoped_ptr here too.
liyanhou
2014/08/04 23:24:16
Done.
| |
| 74 new extensions::NotificationProviderEventRouter(browser()->profile()); | |
| 75 | |
| 76 event_router->CreateNotification( | |
| 77 extension->id(), sender_id1, notification_id1, *options.release()); | |
| 78 | |
| 79 EXPECT_TRUE(catcher.GetNextResult()) << catcher.message(); | |
| 80 } | |
| OLD | NEW |