File: FieldMetadataTest.php

package info (click to toggle)
phpmyadmin 4%3A5.2.2-really%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: sid, trixie
  • size: 140,312 kB
  • sloc: javascript: 228,447; php: 166,904; xml: 17,847; sql: 504; sh: 275; makefile: 209; python: 205
file content (137 lines) | stat: -rw-r--r-- 4,984 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
<?php

declare(strict_types=1);

namespace PhpMyAdmin\Tests;

use PhpMyAdmin\FieldMetadata;
use stdClass;

use const MYSQLI_BLOB_FLAG;
use const MYSQLI_NUM_FLAG;
use const MYSQLI_TYPE_FLOAT;
use const MYSQLI_TYPE_INT24;
use const MYSQLI_TYPE_STRING;

/**
 * @covers \PhpMyAdmin\FieldMetadata
 */
#[\PHPUnit\Framework\Attributes\CoversClass(\PhpMyAdmin\FieldMetadata::class)]
class FieldMetadataTest extends AbstractTestCase
{
    public function testEmptyConstruct(): void
    {
        $fm = new FieldMetadata(-1, 0, (object) []);
        self::assertSame('', $fm->getMappedType());
        self::assertFalse($fm->isBinary());
        self::assertFalse($fm->isEnum());
        self::assertFalse($fm->isUniqueKey());
        self::assertFalse($fm->isUnsigned());
        self::assertFalse($fm->isZerofill());
        self::assertFalse($fm->isSet());
        self::assertFalse($fm->isNotNull());
        self::assertFalse($fm->isPrimaryKey());
        self::assertFalse($fm->isMultipleKey());
        self::assertFalse($fm->isBlob());
    }

    public function testIsBinaryStdClassAsObject(): void
    {
        $obj = new stdClass();
        $obj->charsetnr = 63;
        $fm = new FieldMetadata(MYSQLI_TYPE_STRING, 0, $obj);
        self::assertTrue($fm->isBinary());
        self::assertFalse($fm->isEnum());
        self::assertFalse($fm->isUniqueKey());
        self::assertFalse($fm->isUnsigned());
        self::assertFalse($fm->isZerofill());
        self::assertFalse($fm->isSet());
        self::assertFalse($fm->isNotNull());
        self::assertFalse($fm->isPrimaryKey());
        self::assertFalse($fm->isMultipleKey());
        self::assertFalse($fm->isBlob());
    }

    public function testIsBinaryCustomClassAsObject(): void
    {
        $obj = new stdClass();
        $obj->charsetnr = 63;
        $objmd = new FieldMetadata(MYSQLI_TYPE_STRING, 0, $obj);
        $fm = new FieldMetadata(MYSQLI_TYPE_STRING, 0, $objmd);
        self::assertTrue($fm->isBinary());
        self::assertFalse($fm->isEnum());
        self::assertFalse($fm->isUniqueKey());
        self::assertFalse($fm->isUnsigned());
        self::assertFalse($fm->isZerofill());
        self::assertFalse($fm->isSet());
        self::assertFalse($fm->isNotNull());
        self::assertFalse($fm->isPrimaryKey());
        self::assertFalse($fm->isMultipleKey());
        self::assertFalse($fm->isBlob());
    }

    public function testIsBinary(): void
    {
        $fm = new FieldMetadata(MYSQLI_TYPE_STRING, 0, (object) ['charsetnr' => 63]);
        self::assertTrue($fm->isBinary());
        self::assertFalse($fm->isEnum());
        self::assertFalse($fm->isUniqueKey());
        self::assertFalse($fm->isUnsigned());
        self::assertFalse($fm->isZerofill());
        self::assertFalse($fm->isSet());
        self::assertFalse($fm->isNotNull());
        self::assertFalse($fm->isPrimaryKey());
        self::assertFalse($fm->isMultipleKey());
        self::assertFalse($fm->isBlob());
    }

    public function testIsNumeric(): void
    {
        $fm = new FieldMetadata(MYSQLI_TYPE_INT24, MYSQLI_NUM_FLAG, (object) []);
        self::assertSame('int', $fm->getMappedType());
        self::assertFalse($fm->isBinary());
        self::assertFalse($fm->isEnum());
        self::assertFalse($fm->isUniqueKey());
        self::assertFalse($fm->isUnsigned());
        self::assertFalse($fm->isZerofill());
        self::assertFalse($fm->isSet());
        self::assertFalse($fm->isNotNull());
        self::assertFalse($fm->isPrimaryKey());
        self::assertFalse($fm->isMultipleKey());
        self::assertTrue($fm->isNumeric());
        self::assertFalse($fm->isBlob());
    }

    public function testIsBlob(): void
    {
        $fm = new FieldMetadata(-1, MYSQLI_BLOB_FLAG, (object) []);
        self::assertSame('', $fm->getMappedType());
        self::assertFalse($fm->isBinary());
        self::assertFalse($fm->isEnum());
        self::assertFalse($fm->isUniqueKey());
        self::assertFalse($fm->isUnsigned());
        self::assertFalse($fm->isZerofill());
        self::assertFalse($fm->isSet());
        self::assertFalse($fm->isNotNull());
        self::assertFalse($fm->isPrimaryKey());
        self::assertFalse($fm->isMultipleKey());
        self::assertTrue($fm->isBlob());
    }

    public function testIsNumericFloat(): void
    {
        $fm = new FieldMetadata(MYSQLI_TYPE_FLOAT, MYSQLI_NUM_FLAG, (object) []);
        self::assertSame('real', $fm->getMappedType());
        self::assertFalse($fm->isBinary());
        self::assertFalse($fm->isEnum());
        self::assertFalse($fm->isUniqueKey());
        self::assertFalse($fm->isUnsigned());
        self::assertFalse($fm->isZerofill());
        self::assertFalse($fm->isSet());
        self::assertFalse($fm->isNotNull());
        self::assertFalse($fm->isPrimaryKey());
        self::assertFalse($fm->isMultipleKey());
        self::assertTrue($fm->isNumeric());
        self::assertFalse($fm->isBlob());
    }
}