| OLD | NEW |
| 1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2009 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/http/http_byte_range.h" | 5 #include "net/http/http_byte_range.h" |
| 6 #include "testing/gtest/include/gtest/gtest.h" | 6 #include "testing/gtest/include/gtest/gtest.h" |
| 7 | 7 |
| 8 TEST(HttpByteRangeTest, ValidRanges) { | 8 TEST(HttpByteRangeTest, ValidRanges) { |
| 9 const struct { | 9 const struct { |
| 10 int64 first_byte_position; | 10 int64 first_byte_position; |
| 11 int64 last_byte_position; | 11 int64 last_byte_position; |
| 12 int64 suffix_length; | 12 int64 suffix_length; |
| 13 bool valid; | 13 bool valid; |
| 14 } tests[] = { | 14 } tests[] = { |
| 15 { -1, -1, 0, false }, | 15 { -1, -1, 0, false }, |
| 16 { 0, 0, 0, true }, | 16 { 0, 0, 0, true }, |
| 17 { -10, 0, 0, false }, | 17 { -10, 0, 0, false }, |
| 18 { 10, 0, 0, false }, | 18 { 10, 0, 0, false }, |
| 19 { 10, -1, 0, true }, | 19 { 10, -1, 0, true }, |
| 20 { -1, -1, -1, false }, | 20 { -1, -1, -1, false }, |
| 21 { -1, 50, 0, false }, | 21 { -1, 50, 0, false }, |
| 22 { 10, 10000, 0, true }, | 22 { 10, 10000, 0, true }, |
| 23 { -1, -1, 100000, true }, | 23 { -1, -1, 100000, true }, |
| 24 }; | 24 }; |
| 25 | 25 |
| 26 for (size_t i = 0; i < ARRAYSIZE_UNSAFE(tests); ++i) { | 26 for (size_t i = 0; i < arraysize(tests); ++i) { |
| 27 net::HttpByteRange range; | 27 net::HttpByteRange range; |
| 28 range.set_first_byte_position(tests[i].first_byte_position); | 28 range.set_first_byte_position(tests[i].first_byte_position); |
| 29 range.set_last_byte_position(tests[i].last_byte_position); | 29 range.set_last_byte_position(tests[i].last_byte_position); |
| 30 range.set_suffix_length(tests[i].suffix_length); | 30 range.set_suffix_length(tests[i].suffix_length); |
| 31 EXPECT_EQ(tests[i].valid, range.IsValid()); | 31 EXPECT_EQ(tests[i].valid, range.IsValid()); |
| 32 } | 32 } |
| 33 } | 33 } |
| 34 | 34 |
| 35 TEST(HttpByteRangeTest, SetInstanceSize) { | 35 TEST(HttpByteRangeTest, SetInstanceSize) { |
| 36 const struct { | 36 const struct { |
| (...skipping 11 matching lines...) Expand all Loading... |
| 48 { -1, -1, -1, 0, true, 0, -1 }, | 48 { -1, -1, -1, 0, true, 0, -1 }, |
| 49 { -1, -1, 500, 0, true, 0, -1 }, | 49 { -1, -1, 500, 0, true, 0, -1 }, |
| 50 { -1, 50, -1, 0, false, -1, -1 }, | 50 { -1, 50, -1, 0, false, -1, -1 }, |
| 51 { -1, -1, 500, 300, true, 0, 299 }, | 51 { -1, -1, 500, 300, true, 0, 299 }, |
| 52 { -1, -1, -1, 100, true, 0, 99 }, | 52 { -1, -1, -1, 100, true, 0, 99 }, |
| 53 { 10, -1, -1, 100, true, 10, 99 }, | 53 { 10, -1, -1, 100, true, 10, 99 }, |
| 54 { -1, -1, 500, 1000, true, 500, 999 }, | 54 { -1, -1, 500, 1000, true, 500, 999 }, |
| 55 { 10, 10000, -1, 1000000, true, 10, 10000 }, | 55 { 10, 10000, -1, 1000000, true, 10, 10000 }, |
| 56 }; | 56 }; |
| 57 | 57 |
| 58 for (size_t i = 0; i < ARRAYSIZE_UNSAFE(tests); ++i) { | 58 for (size_t i = 0; i < arraysize(tests); ++i) { |
| 59 net::HttpByteRange range; | 59 net::HttpByteRange range; |
| 60 range.set_first_byte_position(tests[i].first_byte_position); | 60 range.set_first_byte_position(tests[i].first_byte_position); |
| 61 range.set_last_byte_position(tests[i].last_byte_position); | 61 range.set_last_byte_position(tests[i].last_byte_position); |
| 62 range.set_suffix_length(tests[i].suffix_length); | 62 range.set_suffix_length(tests[i].suffix_length); |
| 63 | 63 |
| 64 bool return_value = range.ComputeBounds(tests[i].instance_size); | 64 bool return_value = range.ComputeBounds(tests[i].instance_size); |
| 65 EXPECT_EQ(tests[i].expected_return_value, return_value); | 65 EXPECT_EQ(tests[i].expected_return_value, return_value); |
| 66 if (return_value) { | 66 if (return_value) { |
| 67 EXPECT_EQ(tests[i].expected_lower_bound, range.first_byte_position()); | 67 EXPECT_EQ(tests[i].expected_lower_bound, range.first_byte_position()); |
| 68 EXPECT_EQ(tests[i].expected_upper_bound, range.last_byte_position()); | 68 EXPECT_EQ(tests[i].expected_upper_bound, range.last_byte_position()); |
| (...skipping 10 matching lines...) Expand all Loading... |
| 79 | 79 |
| 80 TEST(HttpByteRangeTest, GetHeaderValue) { | 80 TEST(HttpByteRangeTest, GetHeaderValue) { |
| 81 static const struct { | 81 static const struct { |
| 82 net::HttpByteRange range; | 82 net::HttpByteRange range; |
| 83 const char* expected; | 83 const char* expected; |
| 84 } tests[] = {{net::HttpByteRange::Bounded(0, 0), "bytes=0-0"}, | 84 } tests[] = {{net::HttpByteRange::Bounded(0, 0), "bytes=0-0"}, |
| 85 {net::HttpByteRange::Bounded(0, 100), "bytes=0-100"}, | 85 {net::HttpByteRange::Bounded(0, 100), "bytes=0-100"}, |
| 86 {net::HttpByteRange::Bounded(0, -1), "bytes=0-"}, | 86 {net::HttpByteRange::Bounded(0, -1), "bytes=0-"}, |
| 87 {net::HttpByteRange::RightUnbounded(100), "bytes=100-"}, | 87 {net::HttpByteRange::RightUnbounded(100), "bytes=100-"}, |
| 88 {net::HttpByteRange::Suffix(100), "bytes=-100"}, }; | 88 {net::HttpByteRange::Suffix(100), "bytes=-100"}, }; |
| 89 for (size_t i = 0; i < ARRAYSIZE_UNSAFE(tests); ++i) { | 89 for (size_t i = 0; i < arraysize(tests); ++i) { |
| 90 EXPECT_EQ(tests[i].expected, tests[i].range.GetHeaderValue()); | 90 EXPECT_EQ(tests[i].expected, tests[i].range.GetHeaderValue()); |
| 91 } | 91 } |
| 92 } | 92 } |
| OLD | NEW |