Home | History | Annotate | Download | only in tests
      1 /*
      2  * Copyright 2019 Google Inc.
      3  *
      4  * Use of this source code is governed by a BSD-style license that can be
      5  * found in the LICENSE file.
      6  */
      7 
      8 #include "SkTypes.h"
      9 #include "SkPoint.h"
     10 #include "SkRandom.h"
     11 #include "Test.h"
     12 #include <vector>
     13 
     14 #if SK_SUPPORT_GPU
     15 
     16 #include "GrSamplePatternDictionary.h"
     17 
     18 static SkTArray<SkPoint> make_sample_pattern(const std::vector<SkPoint>& sampleLocations) {
     19     return SkTArray<SkPoint>(sampleLocations.data(), sampleLocations.size());
     20 }
     21 
     22 static SkTArray<SkPoint> make_random_sample_pattern(SkRandom* rand) {
     23     SkTArray<SkPoint> pattern;
     24     int count = rand->nextULessThan(20) + 1;
     25     pattern.reset(count);
     26     for (int i = 0; i < count; ++i) {
     27         pattern[i] = SkPoint::Make(rand->nextF(), rand->nextF());
     28     }
     29     return pattern;
     30 }
     31 
     32 // This test ensures that the sample pattern dictionary caches and retrieves patterns correctly.
     33 DEF_TEST(SamplePatternDictionary, reporter) {
     34     SkTArray<SkTArray<SkPoint>> testPatterns;
     35     testPatterns.push_back() = make_sample_pattern({ // Intel on mac, msaa8, offscreen.
     36         {0.562500, 0.312500},
     37         {0.437500, 0.687500},
     38         {0.812500, 0.562500},
     39         {0.312500, 0.187500},
     40         {0.187500, 0.812500},
     41         {0.062500, 0.437500},
     42         {0.687500, 0.937500},
     43         {0.937500, 0.062500}
     44     });
     45 
     46     testPatterns.push_back() = make_sample_pattern({ // Intel on mac, msaa8, on-screen.
     47         {0.562500, 0.687500},
     48         {0.437500, 0.312500},
     49         {0.812500, 0.437500},
     50         {0.312500, 0.812500},
     51         {0.187500, 0.187500},
     52         {0.062500, 0.562500},
     53         {0.687500, 0.062500},
     54         {0.937500, 0.937500}
     55     });
     56 
     57     testPatterns.push_back() = make_sample_pattern({ // NVIDIA, msaa16.
     58         {0.062500, 0.000000},
     59         {0.250000, 0.125000},
     60         {0.187500, 0.375000},
     61         {0.437500, 0.312500},
     62         {0.500000, 0.062500},
     63         {0.687500, 0.187500},
     64         {0.750000, 0.437500},
     65         {0.937500, 0.250000},
     66         {0.000000, 0.500000},
     67         {0.312500, 0.625000},
     68         {0.125000, 0.750000},
     69         {0.375000, 0.875000},
     70         {0.562500, 0.562500},
     71         {0.812500, 0.687500},
     72         {0.625000, 0.812500},
     73         {0.875000, 0.937500}
     74     });
     75 
     76     testPatterns.push_back() = make_sample_pattern({ // NVIDIA, mixed samples, 16:1.
     77         {0.250000, 0.125000},
     78         {0.625000, 0.812500},
     79         {0.500000, 0.062500},
     80         {0.812500, 0.687500},
     81         {0.187500, 0.375000},
     82         {0.875000, 0.937500},
     83         {0.125000, 0.750000},
     84         {0.750000, 0.437500},
     85         {0.937500, 0.250000},
     86         {0.312500, 0.625000},
     87         {0.437500, 0.312500},
     88         {0.000000, 0.500000},
     89         {0.375000, 0.875000},
     90         {0.687500, 0.187500},
     91         {0.062500, 0.000000},
     92         {0.562500, 0.562500}
     93     });
     94 
     95     SkRandom rand;
     96     for (int i = 0; i < 23; ++i) {
     97         testPatterns.push_back(make_random_sample_pattern(&rand));
     98     }
     99 
    100     // Duplicate the initial 4 patterns, with slight differences.
    101     testPatterns.push_back(testPatterns[0]);
    102     testPatterns.back().back().fX += 0.001f;
    103 
    104     testPatterns.push_back(testPatterns[1]);
    105     testPatterns.back().back().fY -= 0.002f;
    106 
    107     testPatterns.push_back(testPatterns[2]);
    108     testPatterns.back().push_back(SkPoint::Make(.5f, .5f));
    109 
    110     testPatterns.push_back(testPatterns[3]);
    111     testPatterns.back().pop_back();
    112 
    113     for (int i = 0; i < 13; ++i) {
    114         testPatterns.push_back(make_random_sample_pattern(&rand));
    115     }
    116 
    117     GrSamplePatternDictionary dict;
    118     for (int i = 0; i < 2; ++i) {
    119         for (int j = 0; j < testPatterns.count(); ++j) {
    120             for (int k = 0; k < 3; ++k) {
    121                 const SkTArray<SkPoint>& pattern = testPatterns[testPatterns.count() - j - 1];
    122                 REPORTER_ASSERT(reporter, j == dict.findOrAssignSamplePatternKey(pattern));
    123             }
    124         }
    125     }
    126     for (int j = 0; j < testPatterns.count(); ++j) {
    127         const SkTArray<SkPoint>& pattern = testPatterns[testPatterns.count() - j - 1];
    128         REPORTER_ASSERT(reporter, dict.retrieveSampleLocations(j) == pattern);
    129     }
    130 }
    131 
    132 #endif
    133