Do not input private or sensitive data. View Qlik Privacy & Cookie Policy.
Skip to main content

Announcements
Join us to spark ideas for how to put the latest capabilities into action. Register here!
cancel
Showing results for 
Search instead for 
Did you mean: 
Not applicable

Aggr query

Hello,

I have a complex query I am looking help with and would appreciated suggestions how to get it resolved. In the table below I have multiple test sets, and test cases which are attached to each test set (a test set is above a test case in the hiearchy and a test case can be in different test sets, e.g. Test case ID 1).

What I want to find out is the number of Test sets that have been successfully passed (i.e. all test cases within a test set must have a status of "Passed") and also the date at which each have been completed (the date to use would be the max Test case complete date). I want to display the information in a text box and a bar chart. As per my example I have 2 test sets that are passed (Testset1 with a complete date of 21/01/12 and Testset4 with a complete date of 17/02/12).


To get around the issue of Test case ID's being displayed in mulitple Test sets I created a new field and simply mergerd Test Set and Test case ID. I think aggr is the most appropiate method to resolve this but am having issues with this.

Thanks,


Ralph

Test setTest case IDTest case statusTest case complete date
Testset11Passed20/01/12
Testset12Passed20/01/12
Testset13Passed21/01/12
Testset24Passed06/02/12
Testset25Failed06/02/12
Testset36Failed14/02/12
Testset31Passed15/02/12
Testset37Not completed16/02/12
Testset42Passed17/02/12
6 Replies
jagan
Partner - Champion III
Partner - Champion III

Hi,

Please check the attachment for solution.

Regards,

Jagan.

swuehl
MVP
MVP

I think, Jagan solution is just fine.

If you want to play around with aggr() (which you don't necessarily need to, see above) but I find it is interesting to play around with different approaches), you could use a dimension Test set and as expression:

if(

sum(aggr(if([Test case status]<>'Passed',1),[Test set],[Test case ID]))

,0

,FirstSortedValue([Test case complete date],-[Test case complete date])

)

Regards,

Stefan

Not applicable
Author

Many thanks for that, it works in a straight table and a text box. However I can't seem to get it working for a bar chart, am I missing something very simple (which is likely) or can this be done?

Thanks,

Ralph

swuehl
MVP
MVP

What is your dimension in the bar chart? And what do you want to show as y-value (I just assume the Date is not very useful here)?

Not applicable
Author

We want to track the date at which Test Set passes and would have to use the max date of the test case within the test set to show this. I'm thinking some script work would have to be done for this to be shown?

Thanks,


Ralph

jagan
Partner - Champion III
Partner - Champion III

Hi,

What is your dimension?  If it TestSet then you will get 1as pass count for each bar for those Testset who passed all the Test cases.  I think date is not used as Y value.

=Sum(Aggr(If(Count(TestcaseID) = Count({<Testcasestatus={'Passed'}>}TestcaseID), 1, 0), Testset))

Regards,

Jagan.