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 "ipc/ipc_channel_mojo.h" | 5 #include "ipc/ipc_channel_mojo.h" |
6 | 6 |
7 #include <stddef.h> | 7 #include <stddef.h> |
8 #include <stdint.h> | 8 #include <stdint.h> |
9 | 9 |
10 #include <memory> | 10 #include <memory> |
(...skipping 740 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
751 }; | 751 }; |
752 | 752 |
753 class IPCChannelProxyMojoTest : public IPCChannelMojoTestBase { | 753 class IPCChannelProxyMojoTest : public IPCChannelMojoTestBase { |
754 public: | 754 public: |
755 void InitWithMojo(const std::string& client_name) { | 755 void InitWithMojo(const std::string& client_name) { |
756 IPCChannelMojoTestBase::InitWithMojo(client_name); | 756 IPCChannelMojoTestBase::InitWithMojo(client_name); |
757 runner_.reset(new ChannelProxyRunner(TakeHandle(), true)); | 757 runner_.reset(new ChannelProxyRunner(TakeHandle(), true)); |
758 } | 758 } |
759 void CreateProxy(IPC::Listener* listener) { runner_->CreateProxy(listener); } | 759 void CreateProxy(IPC::Listener* listener) { runner_->CreateProxy(listener); } |
760 void RunProxy() { runner_->RunProxy(); } | 760 void RunProxy() { runner_->RunProxy(); } |
| 761 void DestroyProxy() { |
| 762 runner_.reset(); |
| 763 base::RunLoop().RunUntilIdle(); |
| 764 } |
761 | 765 |
762 IPC::ChannelProxy* proxy() { return runner_->proxy(); } | 766 IPC::ChannelProxy* proxy() { return runner_->proxy(); } |
763 | 767 |
764 private: | 768 private: |
765 base::MessageLoop message_loop_; | 769 base::MessageLoop message_loop_; |
766 std::unique_ptr<ChannelProxyRunner> runner_; | 770 std::unique_ptr<ChannelProxyRunner> runner_; |
767 }; | 771 }; |
768 | 772 |
769 class ListenerWithSimpleProxyAssociatedInterface | 773 class ListenerWithSimpleProxyAssociatedInterface |
770 : public IPC::Listener, | 774 : public IPC::Listener, |
(...skipping 30 matching lines...) Expand all Loading... |
801 | 805 |
802 private: | 806 private: |
803 // IPC::mojom::SimpleTestDriver: | 807 // IPC::mojom::SimpleTestDriver: |
804 void ExpectString(const mojo::String& str) override { | 808 void ExpectString(const mojo::String& str) override { |
805 next_expected_string_ = str; | 809 next_expected_string_ = str; |
806 } | 810 } |
807 | 811 |
808 void RequestQuit(const RequestQuitCallback& callback) override { | 812 void RequestQuit(const RequestQuitCallback& callback) override { |
809 received_quit_ = true; | 813 received_quit_ = true; |
810 callback.Run(); | 814 callback.Run(); |
| 815 binding_.Close(); |
811 base::MessageLoop::current()->QuitWhenIdle(); | 816 base::MessageLoop::current()->QuitWhenIdle(); |
812 } | 817 } |
813 | 818 |
814 void BindRequest(IPC::mojom::SimpleTestDriverAssociatedRequest request) { | 819 void BindRequest(IPC::mojom::SimpleTestDriverAssociatedRequest request) { |
815 DCHECK(!binding_.is_bound()); | 820 DCHECK(!binding_.is_bound()); |
816 binding_.Bind(std::move(request)); | 821 binding_.Bind(std::move(request)); |
817 } | 822 } |
818 | 823 |
819 std::string next_expected_string_; | 824 std::string next_expected_string_; |
820 int num_messages_received_ = 0; | 825 int num_messages_received_ = 0; |
(...skipping 10 matching lines...) Expand all Loading... |
831 ListenerWithSimpleProxyAssociatedInterface listener; | 836 ListenerWithSimpleProxyAssociatedInterface listener; |
832 CreateProxy(&listener); | 837 CreateProxy(&listener); |
833 listener.RegisterInterfaceFactory(proxy()); | 838 listener.RegisterInterfaceFactory(proxy()); |
834 RunProxy(); | 839 RunProxy(); |
835 | 840 |
836 base::RunLoop().Run(); | 841 base::RunLoop().Run(); |
837 | 842 |
838 EXPECT_TRUE(WaitForClientShutdown()); | 843 EXPECT_TRUE(WaitForClientShutdown()); |
839 EXPECT_TRUE(listener.received_all_messages()); | 844 EXPECT_TRUE(listener.received_all_messages()); |
840 | 845 |
841 base::RunLoop().RunUntilIdle(); | 846 DestroyProxy(); |
842 } | 847 } |
843 | 848 |
844 class ChannelProxyClient { | 849 class ChannelProxyClient { |
845 public: | 850 public: |
846 void Init(mojo::ScopedMessagePipeHandle handle) { | 851 void Init(mojo::ScopedMessagePipeHandle handle) { |
847 runner_.reset(new ChannelProxyRunner(std::move(handle), false)); | 852 runner_.reset(new ChannelProxyRunner(std::move(handle), false)); |
848 } | 853 } |
849 void CreateProxy(IPC::Listener* listener) { runner_->CreateProxy(listener); } | 854 void CreateProxy(IPC::Listener* listener) { runner_->CreateProxy(listener); } |
850 void RunProxy() { runner_->RunProxy(); } | 855 void RunProxy() { runner_->RunProxy(); } |
| 856 void DestroyProxy() { |
| 857 runner_.reset(); |
| 858 base::RunLoop().RunUntilIdle(); |
| 859 } |
851 | 860 |
852 IPC::ChannelProxy* proxy() { return runner_->proxy(); } | 861 IPC::ChannelProxy* proxy() { return runner_->proxy(); } |
853 | 862 |
854 private: | 863 private: |
855 base::MessageLoop message_loop_; | 864 base::MessageLoop message_loop_; |
856 std::unique_ptr<ChannelProxyRunner> runner_; | 865 std::unique_ptr<ChannelProxyRunner> runner_; |
857 }; | 866 }; |
858 | 867 |
859 class ListenerThatWaitsForConnect : public IPC::Listener { | 868 class DummyListener : public IPC::Listener { |
860 public: | 869 public: |
861 explicit ListenerThatWaitsForConnect(const base::Closure& connect_handler) | |
862 : connect_handler_(connect_handler) {} | |
863 | |
864 // IPC::Listener | 870 // IPC::Listener |
865 bool OnMessageReceived(const IPC::Message& message) override { return true; } | 871 bool OnMessageReceived(const IPC::Message& message) override { return true; } |
866 void OnChannelConnected(int32_t) override { connect_handler_.Run(); } | |
867 | |
868 private: | |
869 base::Closure connect_handler_; | |
870 }; | 872 }; |
871 | 873 |
872 DEFINE_IPC_CHANNEL_MOJO_TEST_CLIENT(ProxyThreadAssociatedInterfaceClient, | 874 DEFINE_IPC_CHANNEL_MOJO_TEST_CLIENT(ProxyThreadAssociatedInterfaceClient, |
873 ChannelProxyClient) { | 875 ChannelProxyClient) { |
874 base::RunLoop connect_loop; | 876 DummyListener listener; |
875 ListenerThatWaitsForConnect listener(connect_loop.QuitClosure()); | |
876 CreateProxy(&listener); | 877 CreateProxy(&listener); |
877 RunProxy(); | 878 RunProxy(); |
878 connect_loop.Run(); | |
879 | 879 |
880 // Send a bunch of interleaved messages, alternating between the associated | 880 // Send a bunch of interleaved messages, alternating between the associated |
881 // interface and a legacy IPC::Message. | 881 // interface and a legacy IPC::Message. |
882 IPC::mojom::SimpleTestDriverAssociatedPtr driver; | 882 IPC::mojom::SimpleTestDriverAssociatedPtr driver; |
883 proxy()->GetRemoteAssociatedInterface(&driver); | 883 proxy()->GetRemoteAssociatedInterface(&driver); |
884 for (int i = 0; i < ListenerWithSimpleProxyAssociatedInterface::kNumMessages; | 884 for (int i = 0; i < ListenerWithSimpleProxyAssociatedInterface::kNumMessages; |
885 ++i) { | 885 ++i) { |
886 std::string str = base::StringPrintf("Hello! %d", i); | 886 std::string str = base::StringPrintf("Hello! %d", i); |
887 driver->ExpectString(str); | 887 driver->ExpectString(str); |
888 SendString(proxy(), str); | 888 SendString(proxy(), str); |
889 } | 889 } |
890 driver->RequestQuit(base::MessageLoop::QuitWhenIdleClosure()); | 890 driver->RequestQuit(base::MessageLoop::QuitWhenIdleClosure()); |
891 base::RunLoop().Run(); | 891 base::RunLoop().Run(); |
| 892 |
| 893 DestroyProxy(); |
892 } | 894 } |
893 | 895 |
894 #if defined(OS_POSIX) | 896 #if defined(OS_POSIX) |
895 | 897 |
896 class ListenerThatExpectsFile : public IPC::Listener { | 898 class ListenerThatExpectsFile : public IPC::Listener { |
897 public: | 899 public: |
898 ListenerThatExpectsFile() : sender_(NULL) {} | 900 ListenerThatExpectsFile() : sender_(NULL) {} |
899 | 901 |
900 ~ListenerThatExpectsFile() override {} | 902 ~ListenerThatExpectsFile() override {} |
901 | 903 |
(...skipping 144 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1046 Connect(&listener); | 1048 Connect(&listener); |
1047 | 1049 |
1048 base::MessageLoop::current()->Run(); | 1050 base::MessageLoop::current()->Run(); |
1049 | 1051 |
1050 Close(); | 1052 Close(); |
1051 } | 1053 } |
1052 | 1054 |
1053 #endif // OS_LINUX | 1055 #endif // OS_LINUX |
1054 | 1056 |
1055 } // namespace | 1057 } // namespace |
OLD | NEW |