Download presentation
Presentation is loading. Please wait.
Published byMaria Rasmussen Modified over 5 years ago
1
1. (50 pts) Concolic testing the sort function
Given C program of the sort function, write down asserts and environment model for concolic testing You have to use depth-first search (DFS) to generate test inputs to cover all possible execution paths To do list: Describe your environment model in detail Describe run-time parameters of CROWN Report concolic testing results Assert violation with a violation test input if any Fix the bug and explain how you fixed it Report concolic testing results on the fixed sort function # of test inputs generated and explain why CROWN generates that number of test inputs Time spent # of branches and branch coverage measured by gcov
2
#include<stdio.h>
#include<assert.h> #define N 5 void sort(int *a, int a_size ) { int i,j, tmp; for(i=0; i<a_size-1; i++) for (j=i+1; j<a_size-1; j++) { if (a[i] > a[j]){ tmp = a[i]; a[i] = a[j]; a[j] = tmp; } void environment_setup(int *a, int a_size) { /* To fill out: Assign random *unique values* to a[], each of * which ranges from 1 to 99 */ int main(){ int data[N], i; environment_setup(data, N); printf("Input: "); for(i=0; i< N; i++) printf("%d,", data[i]); printf("\n"); sort(data, N); printf("Output: "); // Checking the sorted result for(i=0; i < N-1; i++) assert(data[i]<=data[i+1]); }
3
2. (50 pts) Concolic testing the circular queue of positive integers
Given C program of the circular queue, convert asserts and environment model for concolic testing You have to use depth-first search (DFS) to generate test inputs to cover all possible execution paths To do list: Describe your assertion check routine in detail Describe your environment model in detail Describe run-time parameters of CROWN Report concolic testing results Assert violation with a violation test input if any # of test inputs generated Time spent # of branches and branch coverage measured by gcov
4
Circular Queue of Positive Integers
#include<stdio.h> #define SIZE 12 #define EMPTY 0 // We assume that q[] is // empty if head==tail unsigned int q[SIZE],head,tail; void enqueue(unsigned int x) { q[tail]=x; tail=(++tail)%SIZE; } unsigned int dequeue() { unsigned int ret; ret = q[head]; q[head]=0; head= (++head)%SIZE; return ret;} Step 1) 1 2 3 4 5 6 7 8 9 10 11 15 6 9 8 4 head=6 tail=11 Step 2) 3 5 15 6 9 8 4 17 tail=2 head=6 Step 3) 3 5 6 9 8 4 17 tail=2 head=7
5
void enqueue_verify() {
unsigned int x, old_head, old_tail; unsigned int old_q[SIZE], i; __CPROVER_assume(x>0); for(i=0; i < SIZE; i++) old_q[i]=q[i]; old_head=head; old_tail=tail; enqueue(x); assert(q[old_tail]==x); assert(tail== ((old_tail +1) % SIZE)); assert(head==old_head); for(i=0; i < old_tail; i++) assert(old_q[i]==q[i]); for(i=old_tail+1; i < SIZE; i++) assert(old_q[i]==q[i]); } void dequeue_verify() { unsigned int ret, old_head, old_tail; unsigned int old_q[SIZE], i; for(i=0; i < SIZE; i++) old_q[i]=q[i]; old_head=head; old_tail=tail; __CPROVER_assume(head!=tail); ret=dequeue(); assert(ret==old_q[old_head]); assert(q[old_head]== EMPTY); assert(head==(old_head+1)%SIZE); assert(tail==old_tail); for(i=0; i < old_head; i++) assert(old_q[i]==q[i]); for(i=old_head+1; i < SIZE; i++) assert(old_q[i]==q[i]);} int main() {// cbmc q.c –unwind SIZE+2 environment_setup(); enqueue_verify();} int main() {// cbmc q.c –unwind SIZE+2 environment_setup(); dequeue_verify();}
6
#include<stdio.h> #define SIZE 12 #define EMPTY 0
// Initial random queue setting following the script void environment_setup() { int i; for(i=0;i<SIZE;i++) { q[i]=EMPTY;} head=non_det(); __CPROVER_assume(0<= head && head < SIZE); tail=non_det(); __CPROVER_assume(0<= tail && tail < SIZE); if( head < tail) for(i=head; i < tail; i++) { q[i]=non_det(); __CPROVER_assume(0< q[i]); } else if(head > tail) { for(i=0; i < tail; i++) { for(i=head; i < SIZE; i++) { } // We assume that q[] is empty if head==tail #include<stdio.h> #define SIZE 12 #define EMPTY 0 unsigned int q[SIZE],head,tail; void enqueue(unsigned int x) { q[tail]=x; tail=(++tail)%SIZE; } unsigned int dequeue() { unsigned int ret; ret = q[head]; q[head]=0; head= (++head)%SIZE; return ret;
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.