summaryrefslogtreecommitdiffstats
path: root/basic/qa/vba_tests/win32compatb.vb
blob: f729725ea55e27c662b1e8ff481f8cd5b64bd7c3 (plain)
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
'
' This file is part of the LibreOffice project.
'
' This Source Code Form is subject to the terms of the Mozilla Public
' License, v. 2.0. If a copy of the MPL was not distributed with this
' file, You can obtain one at http://mozilla.org/MPL/2.0/.
'
' Test built-in compatibility versions of methods whose absence
' is really felt in VBA, and large numbers of macros import from
' the system.
'
' This module tests different signatures for the same methods.
'

Option VBASupport 1
Option Explicit

Private Type LARGE_INTEGER
    lowpart As Long
    highpart As Long
End Type

Private Declare Function QueryPerformanceCounter Lib "kernel32" (lpPerformanceCount As LARGE_INTEGER) As Long
Private Declare Function QueryPerformanceFrequency Lib "kernel32" (lpFrequency As LARGE_INTEGER) As Long

Function doUnitTest() As String
    TestUtil.TestInit
    verify_win32compatb
    doUnitTest = TestUtil.GetResult()
End Function

Function convertLarge(scratch As LARGE_INTEGER) As Double
    Dim ret As Double
    ret = scratch.highpart
    ret = ret * 65536 * 65536
    ret = ret + scratch.lowpart
    convertLarge = ret
End Function

Sub verify_win32compatb()
    Dim scratch as LARGE_INTEGER
    Dim freq As Double
    Dim count_a As Double
    Dim count_b As Double
    Dim success As Long

    On Error GoTo errorHandler

    success = QueryPerformanceFrequency(scratch)
    TestUtil.Assert(success <> 0, "QueryPerformanceFrequency")
    freq = convertLarge(scratch)
    TestUtil.Assert(freq > 0, "QueryPerformanceFrequency", "perf. frequency is incorrect " & freq)

    success = QueryPerformanceCounter(scratch)
    TestUtil.Assert(success <> 0, "QueryPerformanceCounter")
    count_a = convertLarge(scratch)

'    success = QueryPerformanceCounter(scratch)
'    TestUtil.Assert(success <> 0, "fetching performance count")
'    count_b = convertLarge(scratch)
'    TestUtil.Assert(count_a < count_b, "count mismatch " & count_a & " is > " & count_b)

    Exit Sub
errorHandler:
    TestUtil.ReportErrorHandler("verify_win32compatb", Err, Error$, Erl)
End Sub