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

Side by Side Diff: Source/core/html/parser/HTMLSrcsetParserTest.cpp

Issue 293423002: Refactor srcset parser to align it with spec changes (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Fixed ASSERT Created 6 years, 6 months 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 | « Source/core/html/parser/HTMLSrcsetParser.cpp ('k') | Source/platform/ParsingUtilities.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 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 "config.h" 5 #include "config.h"
6 #include "core/html/parser/HTMLSrcsetParser.h" 6 #include "core/html/parser/HTMLSrcsetParser.h"
7 7
8 #include <gtest/gtest.h> 8 #include <gtest/gtest.h>
9 #include <limits.h> 9 #include <limits.h>
10 10
11 namespace WebCore { 11 namespace WebCore {
12 12
13 typedef struct { 13 typedef struct {
14 float deviceScaleFactor; 14 float deviceScaleFactor;
15 int effectiveSize; 15 int effectiveSize;
16 const char* srcInput; 16 const char* srcInput;
17 const char* srcsetInput; 17 const char* srcsetInput;
18 const char* outputURL; 18 const char* outputURL;
19 float outputScaleFactor; 19 float outputDensity;
20 int outputResourceWidth; 20 int outputResourceWidth;
21 } TestCase; 21 } TestCase;
22 22
23 TEST(HTMLSrcsetParserTest, Basic) 23 TEST(HTMLSrcsetParserTest, Basic)
24 { 24 {
25 TestCase testCases[] = { 25 TestCase testCases[] = {
26 {2.0, -1, "", "1x.gif 1x, 2x.gif 2x", "2x.gif", 2.0, -1}, 26 {2.0, -1, "", "1x.gif 1x, 2x.gif 2x", "2x.gif", 2.0, -1},
27 {2.0, -1, "", "1x.gif 1q, 2x.gif 2x", "2x.gif", 2.0, -1},
28 {1.0, -1, "", "1x.gif 1q, 2x.gif 2x", "1x.gif", 1.0, -1},
29 {1.0, -1, "", "1x.gif 1x 100h, 2x.gif 2x", "2x.gif", 2.0, -1},
30 {1.0, -1, "", "1x.gif 1x 100w, 2x.gif 2x", "2x.gif", 2.0, -1},
31 {1.0, -1, "", "1x.gif 1x 100h 100w, 2x.gif 2x", "2x.gif", 2.0, -1},
27 {2.0, -1, "", "1x.gif 1x, 2x.gif -2x", "1x.gif", 1.0, -1}, 32 {2.0, -1, "", "1x.gif 1x, 2x.gif -2x", "1x.gif", 1.0, -1},
28 {2.0, -1, "", "0x.gif 0x", "0x.gif", 0.0, -1}, 33 {2.0, -1, "", "0x.gif 0x", "0x.gif", 0.0, -1},
29 {2.0, -1, "", "0x.gif -0x", "0x.gif", 0.0, -1}, 34 {2.0, -1, "", "0x.gif -0x", "0x.gif", 0.0, -1},
30 {2.0, -1, "", "neg.gif -2x", "", 1.0, -1}, 35 {2.0, -1, "", "neg.gif -2x", "", 1.0, -1},
31 {2.0, -1, "", "1x.gif 1x, 2x.gif 2q", "1x.gif", 1.0, -1}, 36 {2.0, -1, "", "1x.gif 1x, 2x.gif 2q", "1x.gif", 1.0, -1},
37 {2.0, -1, "", "1x.gif, 2x.gif 2q", "1x.gif", 1.0, -1},
38 {2.0, -1, "", "1x.gif , 2x.gif 2q", "1x.gif", 1.0, -1},
32 {2.0, -1, "1x.gif 1x, 2x.gif 2x", "1x.gif 1x, 2x.gif 2x", "2x.gif", 2.0, -1}, 39 {2.0, -1, "1x.gif 1x, 2x.gif 2x", "1x.gif 1x, 2x.gif 2x", "2x.gif", 2.0, -1},
33 {1.0, -1, "1x.gif 1x, 2x.gif 2x", "1x.gif 1x, 2x.gif 2x", "1x.gif", 1.0, -1}, 40 {1.0, -1, "1x.gif 1x, 2x.gif 2x", "1x.gif 1x, 2x.gif 2x", "1x.gif", 1.0, -1},
34 {1.0, -1, "1x.gif 1x, 2x.gif 2x", "", "1x.gif 1x, 2x.gif 2x", 1.0, -1}, 41 {1.0, -1, "1x.gif 1x, 2x.gif 2x", "", "1x.gif 1x, 2x.gif 2x", 1.0, -1},
35 {2.0, -1, "src.gif", "1x.gif 1x, 2x.gif 2x", "2x.gif", 2.0, -1}, 42 {2.0, -1, "src.gif", "1x.gif 1x, 2x.gif 2x", "2x.gif", 2.0, -1},
36 {1.0, -1, "src.gif", "1x.gif 1x, 2x.gif 2x", "1x.gif", 1.0, -1}, 43 {1.0, -1, "src.gif", "1x.gif 1x, 2x.gif 2x", "1x.gif", 1.0, -1},
37 {1.0, -1, "src.gif", "2x.gif 2x", "src.gif", 1.0, -1}, 44 {1.0, -1, "src.gif", "2x.gif 2x", "src.gif", 1.0, -1},
38 {2.0, -1, "src.gif", "2x.gif 2x", "2x.gif", 2.0, -1}, 45 {2.0, -1, "src.gif", "2x.gif 2x", "2x.gif", 2.0, -1},
39 {1.5, -1, "src.gif", "2x.gif 2x", "2x.gif", 2.0, -1}, 46 {1.5, -1, "src.gif", "2x.gif 2x", "2x.gif", 2.0, -1},
40 {2.5, -1, "src.gif", "2x.gif 2x", "2x.gif", 2.0, -1}, 47 {2.5, -1, "src.gif", "2x.gif 2x", "2x.gif", 2.0, -1},
41 {2.5, -1, "src.gif", "2x.gif 2x, 3x.gif 3x", "3x.gif", 3.0, -1}, 48 {2.5, -1, "src.gif", "2x.gif 2x, 3x.gif 3x", "3x.gif", 3.0, -1},
42 {2.0, -1, "", "1x,, , x ,2x ", "1x,", 1.0, -1}, 49 {2.0, -1, "", "1x,, , x ,2x ", "1x", 1.0, -1},
43 {2.0, -1, "", "1x,, , x ,2x ", "1x,", 1.0, -1}, 50 {2.0, -1, "", "1x,, , x ,2x ", "1x", 1.0, -1},
51 {2.0, -1, "", ",,1x,, , x ,2x ", "1x", 1.0, -1},
52 {2.0, -1, "", ",,1x,,", "1x", 1.0, -1},
53 {2.0, -1, "", ",1x,", "1x", 1.0, -1},
44 {2.0, -1, "", " 1x, 2x.gif 2 x", "2x.gif", 2.0, -1}, 54 {2.0, -1, "", " 1x, 2x.gif 2 x", "2x.gif", 2.0, -1},
45 {2.0, -1, "", " 2x, 1x.gif 1 x", "", 2.0, -1}, 55 {2.0, -1, "", " 2x, 1x.gif 1 x", "", 2.0, -1},
46 {2.0, -1, "", "1x,, , x ,2x , 1x.gif, 3x, 4x.gif 4x 100h, 5x.gif 5, dx.gif dx, 2x.gif 2x ,", "2x.gif", 2.0, -1}, 56 {2.0, -1, "", "1x,, , x ,2x , 1x.gif, 3x, 4x.gif 4x 100z, 5x.gif 5, dx.gif dx, 2x.gif 2x ,", "2x.gif", 2.0, -1},
47 {4.0, -1, "", "1x,, , x ,2x , 1x.gif, 3x, 4x.gif 4x 100h, 5x.gif 5, dx.gif dx, 2x.gif 2x ,", "4x.gif", 4.0, -1}, 57 {4.0, -1, "", "1x,, , x ,2x , 1x.gif, 3x, 4x.gif 4x 100h, 5x.gif 5, dx.gif dx, 2x.gif 2x ,", "2x.gif", 2.0, -1},
48 {1.0, -1, "", "1x,, , x ,2x , 1x.gif, 3x, 4x.gif 4x 100h, 5x.gif 5, dx.gif dx, 2x.gif 2x ,", "1x,", 1.0, -1}, 58 {4.0, -1, "", "1x,, , x ,2x , 1x.gif, 3x, 4x.gif 4x 100z, 5x.gif 5, dx.gif dx, 2x.gif 2x ,", "4x.gif", 4.0, -1},
49 {5.0, -1, "", "1x,, , x ,2x , 1x.gif, 3x, 4x.gif 4x 100h, 5x.gif 5, dx.gif dx, 2x.gif 2x ,", "4x.gif", 4.0, -1}, 59 {1.0, -1, "", "1x,, , x ,2x , 1x.gif, 3x, 4x.gif 4x 100z, 5x.gif 5, dx.gif dx, 2x.gif 2x ,", "1x", 1.0, -1},
60 {5.0, -1, "", "1x,, , x ,2x , 1x.gif, 3x, 4x.gif 4x 100z, 5x.gif 5, dx.gif dx, 2x.gif 2x ,", "4x.gif", 4.0, -1},
50 {2.0, -1, "", "1x.gif 1x,  cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxMDAiIGhlaWdodD0iMTAwIj4KCTxyZWN0IHdp ZHRoPSIxMDAiIGhlaWdodD0iMTAwIiBmaWxsPSJncmVlbiIvPgo8L3N2Zz4K 2x", " iIGhlaWdodD0iMTAwIj4KCTxyZWN0IHdpZHRoPSIxMDAiIGhlaWdodD0iMTAwIiBmaWxsPSJncmVlbiI vPgo8L3N2Zz4K", 2.0, -1 }, 61 {2.0, -1, "", "1x.gif 1x,  cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxMDAiIGhlaWdodD0iMTAwIj4KCTxyZWN0IHdp ZHRoPSIxMDAiIGhlaWdodD0iMTAwIiBmaWxsPSJncmVlbiIvPgo8L3N2Zz4K 2x", " iIGhlaWdodD0iMTAwIj4KCTxyZWN0IHdpZHRoPSIxMDAiIGhlaWdodD0iMTAwIiBmaWxsPSJncmVlbiI vPgo8L3N2Zz4K", 2.0, -1 },
51 {2.0, -1, "1x.gif", " 3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxMDAiIGhlaWdodD0iMTAwIj4KCTxyZWN0IHdpZHRoP SIxMDAiIGhlaWdodD0iMTAwIiBmaWxsPSJncmVlbiIvPgo8L3N2Zz4K 2x", " aWdodD0iMTAwIj4KCTxyZWN0IHdpZHRoPSIxMDAiIGhlaWdodD0iMTAwIiBmaWxsPSJncmVlbiIvPgo8 L3N2Zz4K", 2.0, -1 }, 62 {2.0, -1, "1x.gif", " 3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxMDAiIGhlaWdodD0iMTAwIj4KCTxyZWN0IHdpZHRoP SIxMDAiIGhlaWdodD0iMTAwIiBmaWxsPSJncmVlbiIvPgo8L3N2Zz4K 2x", " aWdodD0iMTAwIj4KCTxyZWN0IHdpZHRoPSIxMDAiIGhlaWdodD0iMTAwIiBmaWxsPSJncmVlbiIvPgo8 L3N2Zz4K", 2.0, -1 },
52 {2.0, -1, "1x.svg#red", "1x.svg#green 2x", "1x.svg#green", 2.0, -1 }, 63 {2.0, -1, "1x.svg#red", "1x.svg#green 2x", "1x.svg#green", 2.0, -1 },
53 {2.0, -1, "", "1x.svg#red 1x, 1x.svg#green 2x", "1x.svg#green", 2.0, -1 }, 64 {2.0, -1, "", "1x.svg#red 1x, 1x.svg#green 2x", "1x.svg#green", 2.0, -1 },
54 {1.0, 400, "", "400.gif 400w, 6000.gif 6000w", "400.gif", 1.0, 400}, 65 {1.0, 400, "", "400.gif 400w, 6000.gif 6000w", "400.gif", 1.0, 400},
66 {1.0, 400, "", "400.gif 400w 400h, 6000.gif 6000w", "400.gif", 1.0, 400} ,
55 {2.0, 400, "", "400.gif 400w, 6000.gif 6000w", "6000.gif", 15.0, 6000}, 67 {2.0, 400, "", "400.gif 400w, 6000.gif 6000w", "6000.gif", 15.0, 6000},
56 {1.0, 400, "src.gif", "800.gif 800w", "800.gif", 2.0, 800}, 68 {1.0, 400, "src.gif", "800.gif 800w", "800.gif", 2.0, 800},
57 {1.0, 400, "src.gif", "0.gif 0w, 800.gif 800w", "800.gif", 2.0, 800}, 69 {1.0, 400, "src.gif", "0.gif 0w, 800.gif 800w", "800.gif", 2.0, 800},
58 {1.0, 400, "src.gif", "0.gif 0w, 2x.gif 2x", "src.gif", 1.0, -1}, 70 {1.0, 400, "src.gif", "0.gif 0w, 2x.gif 2x", "src.gif", 1.0, -1},
59 {1.0, 400, "src.gif", "800.gif 2x, 1600.gif 1600w", "800.gif", 2.0, -1}, 71 {1.0, 400, "src.gif", "800.gif 2x, 1600.gif 1600w", "800.gif", 2.0, -1},
60 {1.0, 400, "", "400.gif 400w, 2x.gif 2x", "400.gif", 1.0, 400}, 72 {1.0, 400, "", "400.gif 400w, 2x.gif 2x", "400.gif", 1.0, 400},
61 {2.0, 400, "", "400.gif 400w, 2x.gif 2x", "2x.gif", 2.0, -1}, 73 {2.0, 400, "", "400.gif 400w, 2x.gif 2x", "2x.gif", 2.0, -1},
62 {1.0, 0, "", "400.gif 400w, 6000.gif 6000w", "400.gif", std::numeric_lim its<float>::infinity(), 400}, 74 {1.0, 0, "", "400.gif 400w, 6000.gif 6000w", "400.gif", std::numeric_lim its<float>::infinity(), 400},
75 {2.0, -1, "", ", 1x.gif 1x, 2x.gif 2x", "2x.gif", 2.0, -1},
76 {1.0, -1, "", ",1x.gif 1x, 2x.gif 2x", "1x.gif", 1.0, -1},
77 {1.0, -1, "", ",1x.gif 1x future-descriptor(3x, 4h, whatever), 2x.gif 2x ", "1x.gif", 1.0, -1},
78 {2.0, -1, "", ",1x.gif 1x future-descriptor(3x, 4h, whatever), 2x.gif 2x ", "2x.gif", 2.0, -1},
63 {0, 0, 0, 0, 0, 0} // Do not remove the terminator line. 79 {0, 0, 0, 0, 0, 0} // Do not remove the terminator line.
64 }; 80 };
65 81
66 for (unsigned i = 0; testCases[i].srcInput; ++i) { 82 for (unsigned i = 0; testCases[i].srcInput; ++i) {
67 TestCase test = testCases[i]; 83 TestCase test = testCases[i];
68 ImageCandidate candidate = bestFitSourceForImageAttributes(test.deviceSc aleFactor, test.effectiveSize, test.srcInput, test.srcsetInput); 84 ImageCandidate candidate = bestFitSourceForImageAttributes(test.deviceSc aleFactor, test.effectiveSize, test.srcInput, test.srcsetInput);
69 ASSERT_EQ(test.outputScaleFactor, candidate.scaleFactor()); 85 ASSERT_EQ(test.outputDensity, candidate.density());
70 ASSERT_EQ(test.outputResourceWidth, candidate.resourceWidth()); 86 ASSERT_EQ(test.outputResourceWidth, candidate.resourceWidth());
71 ASSERT_STREQ(test.outputURL, candidate.toString().ascii().data()); 87 ASSERT_STREQ(test.outputURL, candidate.toString().ascii().data());
72 } 88 }
73 } 89 }
74 90
75 } // namespace 91 } // namespace
OLDNEW
« no previous file with comments | « Source/core/html/parser/HTMLSrcsetParser.cpp ('k') | Source/platform/ParsingUtilities.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698