forked from microsoft/Quantum
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathAssertTests.qs
124 lines (102 loc) · 3.31 KB
/
AssertTests.qs
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
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
namespace Microsoft.Quantum.Tests {
open Microsoft.Quantum.Primitive;
open Microsoft.Quantum.Canon;
open Microsoft.Quantum.Extensions.Testing;
// This file contains very simple tests that should trivially pass
// with the intent of testing the assert and testing harness mechanisms themselves.
operation EmptyTest() : () {
body {
}
}
operation PreparationTest () : () {
body {
using (qubits = Qubit[1]) {
AssertProb([PauliZ], [qubits[0]], Zero, 1.0, "Freshly prepared qubit was not in |0〉 state.", 1e-10);
}
}
}
operation OperationTestShouldFail() : () {
body {
fail "OK";
}
}
function FunctionTestShouldFail() : () {
fail "OK";
}
function AssertEqualTestShouldFail() : () {
AssertAlmostEqual(1.0, 0.0);
}
function AssertBoolArrayEqualTestShouldFail() : () {
AssertBoolArrayEqual([true; false], [false; true], "OK");
}
function AssertBoolEqualTestShouldFail() : () {
AssertBoolEqual(true, false, "OK");
}
function AssertResultEqualTestShouldFail() : () {
AssertResultEqual(Zero, One, "OK");
}
function AssertIntEqualTestShouldFail() : () {
AssertIntEqual(12, 42, "OK");
}
/// # Summary
/// Tests whether common builtin operations are self adjoint.
/// These tests are already performed in Solid itself, such that
/// this operation tests whether we can reproduce that using our
/// operation equality assertions.
operation SelfAdjointOperationsTest() : () {
body {
let ops = [I; X; Y; Z; H];
for (idxOp in 0..Length(ops) - 1) {
AssertOperationsEqualReferenced(ApplyToEach(ops[idxOp], _), ApplyToEachA(ops[idxOp], _), 3);
}
}
}
/// # Summary
/// Performs the same test as SelfAdjointOperationsTest,
/// but using Bind to gather the self-adjoint operations.
///
/// # Remarks
/// Marked as ex-fail due to known issues with Bind.
operation BindSelfAdjointOperationsTestExFail() : () {
body {
let ops = [I; X; Y; Z; H];
for (idxOp in 0..Length(ops) - 1) {
let arr = [ops[idxOp]; Adjoint ops[idxOp]];
let bound = BindCA(arr);
AssertOperationsEqualReferenced(ApplyToEachCA(BindCA(arr), _), ApplyToEachA(I, _), 3);
}
}
}
operation AssertProbIntTest() : () {
body{
let nQubits = 4;
let theta = 0.123;
let prob = 0.015052858190174601589;
let tolerance = 10e-10;
using(qubits = Qubit[4]){
X(qubits[0]);
X(qubits[2]);
Exp([PauliX], theta, [qubits[3]]);
AssertProbInt(5, 1.0 - prob, LittleEndian(qubits), tolerance);
AssertProbInt(13, prob, LittleEndian(qubits), tolerance);
AssertProbIntBE(10, 1.0 - prob, BigEndian(qubits), tolerance);
AssertProbIntBE(11, prob, BigEndian(qubits), tolerance);
ResetAll(qubits);
}
}
}
operation AssertPhaseTest() : () {
body{
let phase = 0.456;
let tolerance = 10e-10;
using(qubits = Qubit[1]){
H(qubits[0]);
Exp([PauliZ], phase, qubits);
AssertPhase(phase, qubits[0], tolerance);
ResetAll(qubits);
}
}
}
}