Ignore:
File:
1 edited

Legend:

Unmodified
Added
Removed
  • uspace/lib/ui/test/resource.c

    rfaca61b8 r1fa6292  
    11/*
    2  * Copyright (c) 2020 Jiri Svoboda
     2 * Copyright (c) 2021 Jiri Svoboda
    33 * All rights reserved.
    44 *
     
    3333#include <ui/resource.h>
    3434#include "../private/resource.h"
     35#include "../private/testgc.h"
    3536
    3637PCUT_INIT;
     
    3839PCUT_TEST_SUITE(resource);
    3940
    40 static errno_t testgc_bitmap_create(void *, gfx_bitmap_params_t *,
    41     gfx_bitmap_alloc_t *, void **);
    42 static errno_t testgc_bitmap_destroy(void *);
    43 static errno_t testgc_bitmap_render(void *, gfx_rect_t *, gfx_coord2_t *);
    44 static errno_t testgc_bitmap_get_alloc(void *, gfx_bitmap_alloc_t *);
    45 
    46 static gfx_context_ops_t ops = {
    47         .bitmap_create = testgc_bitmap_create,
    48         .bitmap_destroy = testgc_bitmap_destroy,
    49         .bitmap_render = testgc_bitmap_render,
    50         .bitmap_get_alloc = testgc_bitmap_get_alloc
    51 };
     41static void test_expose(void *);
    5242
    5343typedef struct {
    54         bool bm_created;
    55         bool bm_destroyed;
    56         gfx_bitmap_params_t bm_params;
    57         void *bm_pixels;
    58         gfx_rect_t bm_srect;
    59         gfx_coord2_t bm_offs;
    60         bool bm_rendered;
    61         bool bm_got_alloc;
    62 } test_gc_t;
    63 
    64 typedef struct {
    65         test_gc_t *tgc;
    66         gfx_bitmap_alloc_t alloc;
    67         bool myalloc;
    68 } testgc_bitmap_t;
     44        bool expose;
     45} test_resp_t;
    6946
    7047/** Create and destroy UI resource */
     
    8057        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    8158
    82         rc = ui_resource_create(gc, &resource);
     59        rc = ui_resource_create(gc, false, &resource);
    8360        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    8461        PCUT_ASSERT_NOT_NULL(resource);
     
    9976}
    10077
    101 static errno_t testgc_bitmap_create(void *arg, gfx_bitmap_params_t *params,
    102     gfx_bitmap_alloc_t *alloc, void **rbm)
    103 {
    104         test_gc_t *tgc = (test_gc_t *) arg;
    105         testgc_bitmap_t *tbm;
    106 
    107         tbm = calloc(1, sizeof(testgc_bitmap_t));
    108         if (tbm == NULL)
    109                 return ENOMEM;
    110 
    111         if (alloc == NULL) {
    112                 tbm->alloc.pitch = (params->rect.p1.x - params->rect.p0.x) *
    113                     sizeof(uint32_t);
    114                 tbm->alloc.off0 = 0;
    115                 tbm->alloc.pixels = calloc(sizeof(uint32_t),
    116                     (params->rect.p1.x - params->rect.p0.x) *
    117                     (params->rect.p1.y - params->rect.p0.y));
    118                 tbm->myalloc = true;
    119                 if (tbm->alloc.pixels == NULL) {
    120                         free(tbm);
    121                         return ENOMEM;
    122                 }
    123         } else {
    124                 tbm->alloc = *alloc;
    125         }
    126 
    127         tbm->tgc = tgc;
    128         tgc->bm_created = true;
    129         tgc->bm_params = *params;
    130         tgc->bm_pixels = tbm->alloc.pixels;
    131         *rbm = (void *)tbm;
    132         return EOK;
    133 }
    134 
    135 static errno_t testgc_bitmap_destroy(void *bm)
    136 {
    137         testgc_bitmap_t *tbm = (testgc_bitmap_t *)bm;
    138         if (tbm->myalloc)
    139                 free(tbm->alloc.pixels);
    140         tbm->tgc->bm_destroyed = true;
    141         free(tbm);
    142         return EOK;
    143 }
    144 
    145 static errno_t testgc_bitmap_render(void *bm, gfx_rect_t *srect,
    146     gfx_coord2_t *offs)
    147 {
    148         testgc_bitmap_t *tbm = (testgc_bitmap_t *)bm;
    149         tbm->tgc->bm_rendered = true;
    150         tbm->tgc->bm_srect = *srect;
    151         tbm->tgc->bm_offs = *offs;
    152         return EOK;
    153 }
    154 
    155 static errno_t testgc_bitmap_get_alloc(void *bm, gfx_bitmap_alloc_t *alloc)
    156 {
    157         testgc_bitmap_t *tbm = (testgc_bitmap_t *)bm;
    158         *alloc = tbm->alloc;
    159         tbm->tgc->bm_got_alloc = true;
    160         return EOK;
     78/** ui_resource_set_expose_cb() / ui_resource_expose() */
     79PCUT_TEST(set_expose_cb_expose)
     80{
     81        errno_t rc;
     82        gfx_context_t *gc = NULL;
     83        test_gc_t tgc;
     84        ui_resource_t *resource = NULL;
     85        test_resp_t resp;
     86
     87        memset(&tgc, 0, sizeof(tgc));
     88        rc = gfx_context_new(&ops, &tgc, &gc);
     89        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
     90
     91        rc = ui_resource_create(gc, false, &resource);
     92        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
     93        PCUT_ASSERT_NOT_NULL(resource);
     94
     95        ui_resource_set_expose_cb(resource, test_expose, &resp);
     96
     97        resp.expose = false;
     98        ui_resource_expose(resource);
     99        PCUT_ASSERT_TRUE(resp.expose);
     100
     101        ui_resource_destroy(resource);
     102
     103        rc = gfx_context_delete(gc);
     104        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
     105}
     106
     107/** ui_resource_get_font() returns the font */
     108PCUT_TEST(get_font)
     109{
     110        errno_t rc;
     111        gfx_context_t *gc = NULL;
     112        test_gc_t tgc;
     113        ui_resource_t *resource = NULL;
     114        gfx_font_t *font;
     115
     116        memset(&tgc, 0, sizeof(tgc));
     117        rc = gfx_context_new(&ops, &tgc, &gc);
     118        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
     119
     120        rc = ui_resource_create(gc, false, &resource);
     121        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
     122        PCUT_ASSERT_NOT_NULL(resource);
     123
     124        font = ui_resource_get_font(resource);
     125        PCUT_ASSERT_EQUALS(resource->font, font);
     126
     127        ui_resource_destroy(resource);
     128
     129        rc = gfx_context_delete(gc);
     130        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
     131}
     132
     133/** ui_resource_is_textmode() returns the textmode flag */
     134PCUT_TEST(is_textmode)
     135{
     136        errno_t rc;
     137        gfx_context_t *gc = NULL;
     138        test_gc_t tgc;
     139        ui_resource_t *resource = NULL;
     140
     141        memset(&tgc, 0, sizeof(tgc));
     142        rc = gfx_context_new(&ops, &tgc, &gc);
     143        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
     144
     145        rc = ui_resource_create(gc, false, &resource);
     146        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
     147        PCUT_ASSERT_NOT_NULL(resource);
     148
     149        /* To make sure let's test both true and false case */
     150        resource->textmode = true;
     151        PCUT_ASSERT_TRUE(ui_resource_is_textmode(resource));
     152        resource->textmode = false;
     153        PCUT_ASSERT_FALSE(ui_resource_is_textmode(resource));
     154
     155        ui_resource_destroy(resource);
     156
     157        rc = gfx_context_delete(gc);
     158        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
     159}
     160
     161/** ui_resource_get_wnd_face_color() returns window face color */
     162PCUT_TEST(get_wnd_face_color)
     163{
     164        errno_t rc;
     165        gfx_context_t *gc = NULL;
     166        test_gc_t tgc;
     167        ui_resource_t *resource = NULL;
     168        gfx_color_t *color;
     169
     170        memset(&tgc, 0, sizeof(tgc));
     171        rc = gfx_context_new(&ops, &tgc, &gc);
     172        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
     173
     174        rc = ui_resource_create(gc, false, &resource);
     175        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
     176        PCUT_ASSERT_NOT_NULL(resource);
     177
     178        color = ui_resource_get_wnd_face_color(resource);
     179        PCUT_ASSERT_EQUALS(resource->wnd_face_color, color);
     180
     181        ui_resource_destroy(resource);
     182
     183        rc = gfx_context_delete(gc);
     184        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
     185}
     186
     187/** ui_resource_get_wnd_text_color() returns window text color */
     188PCUT_TEST(get_wnd_text_color)
     189{
     190        errno_t rc;
     191        gfx_context_t *gc = NULL;
     192        test_gc_t tgc;
     193        ui_resource_t *resource = NULL;
     194        gfx_color_t *color;
     195
     196        memset(&tgc, 0, sizeof(tgc));
     197        rc = gfx_context_new(&ops, &tgc, &gc);
     198        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
     199
     200        rc = ui_resource_create(gc, false, &resource);
     201        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
     202        PCUT_ASSERT_NOT_NULL(resource);
     203
     204        color = ui_resource_get_wnd_text_color(resource);
     205        PCUT_ASSERT_EQUALS(resource->wnd_text_color, color);
     206
     207        ui_resource_destroy(resource);
     208
     209        rc = gfx_context_delete(gc);
     210        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
     211}
     212
     213static void test_expose(void *arg)
     214{
     215        test_resp_t *resp = (test_resp_t *) arg;
     216
     217        resp->expose = true;
    161218}
    162219
Note: See TracChangeset for help on using the changeset viewer.