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

Side by Side Diff: net/url_request/url_fetcher_impl_unittest.cc

Issue 1502503004: Remove kuint64max. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@kint8
Patch Set: rebase Created 5 years 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 unified diff | Download patch
« no previous file with comments | « net/url_request/url_fetcher_impl.cc ('k') | net/url_request/url_request.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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 "net/url_request/url_fetcher_impl.h" 5 #include "net/url_request/url_fetcher_impl.h"
6 6
7 #include <stdint.h> 7 #include <stdint.h>
8 #include <string.h> 8 #include <string.h>
9 9
10 #include <algorithm> 10 #include <algorithm>
11 #include <limits>
11 #include <string> 12 #include <string>
12 13
13 #include "base/bind.h" 14 #include "base/bind.h"
14 #include "base/files/file_path.h" 15 #include "base/files/file_path.h"
15 #include "base/files/file_util.h" 16 #include "base/files/file_util.h"
16 #include "base/files/scoped_temp_dir.h" 17 #include "base/files/scoped_temp_dir.h"
17 #include "base/location.h" 18 #include "base/location.h"
18 #include "base/macros.h" 19 #include "base/macros.h"
19 #include "base/memory/scoped_ptr.h" 20 #include "base/memory/scoped_ptr.h"
20 #include "base/path_service.h" 21 #include "base/path_service.h"
(...skipping 90 matching lines...) Expand 10 before | Expand all | Expand 10 after
111 // URLFetcherDelegate: 112 // URLFetcherDelegate:
112 void OnURLFetchComplete(const URLFetcher* source) override { 113 void OnURLFetchComplete(const URLFetcher* source) override {
113 EXPECT_FALSE(did_complete_); 114 EXPECT_FALSE(did_complete_);
114 EXPECT_TRUE(fetcher_); 115 EXPECT_TRUE(fetcher_);
115 EXPECT_EQ(fetcher_.get(), source); 116 EXPECT_EQ(fetcher_.get(), source);
116 did_complete_ = true; 117 did_complete_ = true;
117 run_loop_.Quit(); 118 run_loop_.Quit();
118 } 119 }
119 120
120 void OnURLFetchDownloadProgress(const URLFetcher* source, 121 void OnURLFetchDownloadProgress(const URLFetcher* source,
121 int64 current, 122 int64_t current,
122 int64 total) override { 123 int64_t total) override {
123 // Note that the current progress may be greater than the previous progress, 124 // Note that the current progress may be greater than the previous progress,
124 // in the case of retrying the request. 125 // in the case of retrying the request.
125 EXPECT_FALSE(did_complete_); 126 EXPECT_FALSE(did_complete_);
126 EXPECT_TRUE(fetcher_); 127 EXPECT_TRUE(fetcher_);
127 EXPECT_EQ(source, fetcher_.get()); 128 EXPECT_EQ(source, fetcher_.get());
128 129
129 EXPECT_LE(0, current); 130 EXPECT_LE(0, current);
130 // If file size is not known, |total| is -1. 131 // If file size is not known, |total| is -1.
131 if (total >= 0) 132 if (total >= 0)
132 EXPECT_LE(current, total); 133 EXPECT_LE(current, total);
133 } 134 }
134 135
135 void OnURLFetchUploadProgress(const URLFetcher* source, 136 void OnURLFetchUploadProgress(const URLFetcher* source,
136 int64 current, 137 int64_t current,
137 int64 total) override { 138 int64_t total) override {
138 // Note that the current progress may be greater than the previous progress, 139 // Note that the current progress may be greater than the previous progress,
139 // in the case of retrying the request. 140 // in the case of retrying the request.
140 EXPECT_FALSE(did_complete_); 141 EXPECT_FALSE(did_complete_);
141 EXPECT_TRUE(fetcher_); 142 EXPECT_TRUE(fetcher_);
142 EXPECT_EQ(source, fetcher_.get()); 143 EXPECT_EQ(source, fetcher_.get());
143 144
144 EXPECT_LE(0, current); 145 EXPECT_LE(0, current);
145 // If file size is not known, |total| is -1. 146 // If file size is not known, |total| is -1.
146 if (total >= 0) 147 if (total >= 0)
147 EXPECT_LE(current, total); 148 EXPECT_LE(current, total);
(...skipping 545 matching lines...) Expand 10 before | Expand all | Expand 10 after
693 EXPECT_EQ(kUploadData, data); 694 EXPECT_EQ(kUploadData, data);
694 } 695 }
695 696
696 TEST_F(URLFetcherTest, PostEntireFile) { 697 TEST_F(URLFetcherTest, PostEntireFile) {
697 base::FilePath upload_path = GetUploadFileTestPath(); 698 base::FilePath upload_path = GetUploadFileTestPath();
698 699
699 WaitingURLFetcherDelegate delegate; 700 WaitingURLFetcherDelegate delegate;
700 delegate.CreateFetcher(test_server_->GetURL("/echo"), URLFetcher::POST, 701 delegate.CreateFetcher(test_server_->GetURL("/echo"), URLFetcher::POST,
701 CreateSameThreadContextGetter()); 702 CreateSameThreadContextGetter());
702 delegate.fetcher()->SetUploadFilePath("application/x-www-form-urlencoded", 703 delegate.fetcher()->SetUploadFilePath("application/x-www-form-urlencoded",
703 upload_path, 0, kuint64max, 704 upload_path, 0,
705 std::numeric_limits<uint64_t>::max(),
704 base::ThreadTaskRunnerHandle::Get()); 706 base::ThreadTaskRunnerHandle::Get());
705 delegate.StartFetcherAndWait(); 707 delegate.StartFetcherAndWait();
706 708
707 EXPECT_TRUE(delegate.fetcher()->GetStatus().is_success()); 709 EXPECT_TRUE(delegate.fetcher()->GetStatus().is_success());
708 EXPECT_EQ(200, delegate.fetcher()->GetResponseCode()); 710 EXPECT_EQ(200, delegate.fetcher()->GetResponseCode());
709 711
710 std::string expected; 712 std::string expected;
711 ASSERT_TRUE(base::ReadFileToString(upload_path, &expected)); 713 ASSERT_TRUE(base::ReadFileToString(upload_path, &expected));
712 std::string data; 714 std::string data;
713 ASSERT_TRUE(delegate.fetcher()->GetResponseAsString(&data)); 715 ASSERT_TRUE(delegate.fetcher()->GetResponseAsString(&data));
(...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after
776 // Checks that upload progress increases over time, never exceeds what's already 778 // Checks that upload progress increases over time, never exceeds what's already
777 // been sent, and adds a chunk whenever all previously appended chunks have 779 // been sent, and adds a chunk whenever all previously appended chunks have
778 // been uploaded. 780 // been uploaded.
779 class CheckUploadProgressDelegate : public WaitingURLFetcherDelegate { 781 class CheckUploadProgressDelegate : public WaitingURLFetcherDelegate {
780 public: 782 public:
781 CheckUploadProgressDelegate() 783 CheckUploadProgressDelegate()
782 : chunk_(1 << 16, 'a'), num_chunks_appended_(0), last_seen_progress_(0) {} 784 : chunk_(1 << 16, 'a'), num_chunks_appended_(0), last_seen_progress_(0) {}
783 ~CheckUploadProgressDelegate() override {} 785 ~CheckUploadProgressDelegate() override {}
784 786
785 void OnURLFetchUploadProgress(const URLFetcher* source, 787 void OnURLFetchUploadProgress(const URLFetcher* source,
786 int64 current, 788 int64_t current,
787 int64 total) override { 789 int64_t total) override {
788 // Run default checks. 790 // Run default checks.
789 WaitingURLFetcherDelegate::OnURLFetchUploadProgress(source, current, total); 791 WaitingURLFetcherDelegate::OnURLFetchUploadProgress(source, current, total);
790 792
791 EXPECT_LE(last_seen_progress_, current); 793 EXPECT_LE(last_seen_progress_, current);
792 EXPECT_LE(current, bytes_appended()); 794 EXPECT_LE(current, bytes_appended());
793 last_seen_progress_ = current; 795 last_seen_progress_ = current;
794 MaybeAppendChunk(); 796 MaybeAppendChunk();
795 } 797 }
796 798
797 // Append the next chunk if all previously appended chunks have been sent. 799 // Append the next chunk if all previously appended chunks have been sent.
798 void MaybeAppendChunk() { 800 void MaybeAppendChunk() {
799 const int kNumChunks = 5; 801 const int kNumChunks = 5;
800 if (last_seen_progress_ == bytes_appended() && 802 if (last_seen_progress_ == bytes_appended() &&
801 num_chunks_appended_ < kNumChunks) { 803 num_chunks_appended_ < kNumChunks) {
802 ++num_chunks_appended_; 804 ++num_chunks_appended_;
803 fetcher()->AppendChunkToUpload(chunk_, 805 fetcher()->AppendChunkToUpload(chunk_,
804 num_chunks_appended_ == kNumChunks); 806 num_chunks_appended_ == kNumChunks);
805 } 807 }
806 } 808 }
807 809
808 private: 810 private:
809 int64 bytes_appended() const { return num_chunks_appended_ * chunk_.size(); } 811 int64_t bytes_appended() const {
812 return num_chunks_appended_ * chunk_.size();
813 }
810 814
811 const std::string chunk_; 815 const std::string chunk_;
812 816
813 int64 num_chunks_appended_; 817 int64_t num_chunks_appended_;
814 int64 last_seen_progress_; 818 int64_t last_seen_progress_;
815 819
816 DISALLOW_COPY_AND_ASSIGN(CheckUploadProgressDelegate); 820 DISALLOW_COPY_AND_ASSIGN(CheckUploadProgressDelegate);
817 }; 821 };
818 822
819 TEST_F(URLFetcherTest, UploadProgress) { 823 TEST_F(URLFetcherTest, UploadProgress) {
820 CheckUploadProgressDelegate delegate; 824 CheckUploadProgressDelegate delegate;
821 delegate.CreateFetcher(test_server_->GetURL("/echo"), URLFetcher::POST, 825 delegate.CreateFetcher(test_server_->GetURL("/echo"), URLFetcher::POST,
822 CreateSameThreadContextGetter()); 826 CreateSameThreadContextGetter());
823 // Use a chunked upload so that the upload can be paused after uploading data. 827 // Use a chunked upload so that the upload can be paused after uploading data.
824 // Since upload progress uses a timer, the delegate may not receive any 828 // Since upload progress uses a timer, the delegate may not receive any
(...skipping 11 matching lines...) Expand all
836 840
837 EXPECT_TRUE(delegate.fetcher()->GetStatus().is_success()); 841 EXPECT_TRUE(delegate.fetcher()->GetStatus().is_success());
838 EXPECT_EQ(200, delegate.fetcher()->GetResponseCode()); 842 EXPECT_EQ(200, delegate.fetcher()->GetResponseCode());
839 EXPECT_TRUE(delegate.did_complete()); 843 EXPECT_TRUE(delegate.did_complete());
840 } 844 }
841 845
842 // Checks that download progress never decreases, never exceeds file size, and 846 // Checks that download progress never decreases, never exceeds file size, and
843 // that file size is correctly reported. 847 // that file size is correctly reported.
844 class CheckDownloadProgressDelegate : public WaitingURLFetcherDelegate { 848 class CheckDownloadProgressDelegate : public WaitingURLFetcherDelegate {
845 public: 849 public:
846 CheckDownloadProgressDelegate(int64 file_size) 850 CheckDownloadProgressDelegate(int64_t file_size)
847 : file_size_(file_size), last_seen_progress_(0) {} 851 : file_size_(file_size), last_seen_progress_(0) {}
848 ~CheckDownloadProgressDelegate() override {} 852 ~CheckDownloadProgressDelegate() override {}
849 853
850 void OnURLFetchDownloadProgress(const URLFetcher* source, 854 void OnURLFetchDownloadProgress(const URLFetcher* source,
851 int64 current, 855 int64_t current,
852 int64 total) override { 856 int64_t total) override {
853 // Run default checks. 857 // Run default checks.
854 WaitingURLFetcherDelegate::OnURLFetchDownloadProgress(source, current, 858 WaitingURLFetcherDelegate::OnURLFetchDownloadProgress(source, current,
855 total); 859 total);
856 860
857 EXPECT_LE(last_seen_progress_, current); 861 EXPECT_LE(last_seen_progress_, current);
858 EXPECT_EQ(file_size_, total); 862 EXPECT_EQ(file_size_, total);
859 last_seen_progress_ = current; 863 last_seen_progress_ = current;
860 } 864 }
861 865
862 private: 866 private:
863 int64 file_size_; 867 int64_t file_size_;
864 int64 last_seen_progress_; 868 int64_t last_seen_progress_;
865 869
866 DISALLOW_COPY_AND_ASSIGN(CheckDownloadProgressDelegate); 870 DISALLOW_COPY_AND_ASSIGN(CheckDownloadProgressDelegate);
867 }; 871 };
868 872
869 TEST_F(URLFetcherTest, DownloadProgress) { 873 TEST_F(URLFetcherTest, DownloadProgress) {
870 // Get a file large enough to require more than one read into 874 // Get a file large enough to require more than one read into
871 // URLFetcher::Core's IOBuffer. 875 // URLFetcher::Core's IOBuffer.
872 const char kFileToFetch[] = "animate1.gif"; 876 const char kFileToFetch[] = "animate1.gif";
873 877
874 std::string file_contents; 878 std::string file_contents;
(...skipping 16 matching lines...) Expand all
891 ASSERT_TRUE(delegate.fetcher()->GetResponseAsString(&data)); 895 ASSERT_TRUE(delegate.fetcher()->GetResponseAsString(&data));
892 EXPECT_EQ(file_contents, data); 896 EXPECT_EQ(file_contents, data);
893 } 897 }
894 898
895 class CancelOnUploadProgressDelegate : public WaitingURLFetcherDelegate { 899 class CancelOnUploadProgressDelegate : public WaitingURLFetcherDelegate {
896 public: 900 public:
897 CancelOnUploadProgressDelegate() {} 901 CancelOnUploadProgressDelegate() {}
898 ~CancelOnUploadProgressDelegate() override {} 902 ~CancelOnUploadProgressDelegate() override {}
899 903
900 void OnURLFetchUploadProgress(const URLFetcher* source, 904 void OnURLFetchUploadProgress(const URLFetcher* source,
901 int64 current, 905 int64_t current,
902 int64 total) override { 906 int64_t total) override {
903 CancelFetch(); 907 CancelFetch();
904 } 908 }
905 909
906 private: 910 private:
907 DISALLOW_COPY_AND_ASSIGN(CancelOnUploadProgressDelegate); 911 DISALLOW_COPY_AND_ASSIGN(CancelOnUploadProgressDelegate);
908 }; 912 };
909 913
910 // Check that a fetch can be safely cancelled/deleted during an upload progress 914 // Check that a fetch can be safely cancelled/deleted during an upload progress
911 // callback. 915 // callback.
912 TEST_F(URLFetcherTest, CancelInUploadProgressCallback) { 916 TEST_F(URLFetcherTest, CancelInUploadProgressCallback) {
(...skipping 15 matching lines...) Expand all
928 EXPECT_FALSE(delegate.did_complete()); 932 EXPECT_FALSE(delegate.did_complete());
929 EXPECT_FALSE(delegate.fetcher()); 933 EXPECT_FALSE(delegate.fetcher());
930 } 934 }
931 935
932 class CancelOnDownloadProgressDelegate : public WaitingURLFetcherDelegate { 936 class CancelOnDownloadProgressDelegate : public WaitingURLFetcherDelegate {
933 public: 937 public:
934 CancelOnDownloadProgressDelegate() {} 938 CancelOnDownloadProgressDelegate() {}
935 ~CancelOnDownloadProgressDelegate() override {} 939 ~CancelOnDownloadProgressDelegate() override {}
936 940
937 void OnURLFetchDownloadProgress(const URLFetcher* source, 941 void OnURLFetchDownloadProgress(const URLFetcher* source,
938 int64 current, 942 int64_t current,
939 int64 total) override { 943 int64_t total) override {
940 CancelFetch(); 944 CancelFetch();
941 } 945 }
942 946
943 private: 947 private:
944 DISALLOW_COPY_AND_ASSIGN(CancelOnDownloadProgressDelegate); 948 DISALLOW_COPY_AND_ASSIGN(CancelOnDownloadProgressDelegate);
945 }; 949 };
946 950
947 // Check that a fetch can be safely cancelled/deleted during a download progress 951 // Check that a fetch can be safely cancelled/deleted during a download progress
948 // callback. 952 // callback.
949 TEST_F(URLFetcherTest, CancelInDownloadProgressCallback) { 953 TEST_F(URLFetcherTest, CancelInDownloadProgressCallback) {
(...skipping 473 matching lines...) Expand 10 before | Expand all | Expand 10 after
1423 EXPECT_EQ(-1, delegate.fetcher()->GetResponseCode()); 1427 EXPECT_EQ(-1, delegate.fetcher()->GetResponseCode());
1424 EXPECT_TRUE(delegate.fetcher()->GetCookies().empty()); 1428 EXPECT_TRUE(delegate.fetcher()->GetCookies().empty());
1425 std::string data; 1429 std::string data;
1426 EXPECT_TRUE(delegate.fetcher()->GetResponseAsString(&data)); 1430 EXPECT_TRUE(delegate.fetcher()->GetResponseAsString(&data));
1427 EXPECT_TRUE(data.empty()); 1431 EXPECT_TRUE(data.empty());
1428 } 1432 }
1429 1433
1430 } // namespace 1434 } // namespace
1431 1435
1432 } // namespace net 1436 } // namespace net
OLDNEW
« no previous file with comments | « net/url_request/url_fetcher_impl.cc ('k') | net/url_request/url_request.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698