xref: /libCEED/tests/t403-qfunction.c (revision 9560d06a92c065fb7d600a8c20ade8d9a4cda324)
1*9560d06aSjeremylt /// @file
2*9560d06aSjeremylt /// Test creation, copying, and destruction for QFunction and QFunctionContext
3*9560d06aSjeremylt /// \test Test creation, copying, and destruction for QFunction and QFunctionContext
4*9560d06aSjeremylt #include <ceed.h>
5*9560d06aSjeremylt #include "t400-qfunction.h"
6*9560d06aSjeremylt 
7*9560d06aSjeremylt int main(int argc, char **argv) {
8*9560d06aSjeremylt   Ceed ceed;
9*9560d06aSjeremylt   CeedQFunction qf, qf_2;
10*9560d06aSjeremylt   CeedQFunctionContext ctx, ctx_2;
11*9560d06aSjeremylt 
12*9560d06aSjeremylt   CeedInit(argv[1], &ceed);
13*9560d06aSjeremylt 
14*9560d06aSjeremylt   CeedQFunctionCreateInterior(ceed, 1, setup, setup_loc, &qf);
15*9560d06aSjeremylt   CeedQFunctionCreateInterior(ceed, 1, mass, mass_loc, &qf_2);
16*9560d06aSjeremylt 
17*9560d06aSjeremylt   CeedQFunctionReferenceCopy(qf, &qf_2); // This destroys the previous qf_2
18*9560d06aSjeremylt   if (qf != qf_2)
19*9560d06aSjeremylt     // LCOV_EXCL_START
20*9560d06aSjeremylt     printf("Error copying CeedQFunction reference.");
21*9560d06aSjeremylt   // LCOV_EXCL_STOP
22*9560d06aSjeremylt 
23*9560d06aSjeremylt   CeedQFunctionContextCreate(ceed, &ctx);
24*9560d06aSjeremylt   CeedQFunctionContextCreate(ceed, &ctx_2);
25*9560d06aSjeremylt 
26*9560d06aSjeremylt   CeedQFunctionContextReferenceCopy(ctx, &ctx_2);
27*9560d06aSjeremylt   if (ctx != ctx_2)
28*9560d06aSjeremylt     // LCOV_EXCL_START
29*9560d06aSjeremylt     printf("Error copying CeedQFunctionContext reference.");
30*9560d06aSjeremylt   // LCOV_EXCL_STOP
31*9560d06aSjeremylt 
32*9560d06aSjeremylt   CeedQFunctionDestroy(&qf);
33*9560d06aSjeremylt   CeedQFunctionDestroy(&qf_2);
34*9560d06aSjeremylt   CeedQFunctionContextDestroy(&ctx);
35*9560d06aSjeremylt   CeedQFunctionContextDestroy(&ctx_2);
36*9560d06aSjeremylt   CeedDestroy(&ceed);
37*9560d06aSjeremylt   return 0;
38*9560d06aSjeremylt }
39