January 15, 2020
      
                  
        
  Author(s)
  David R. Kuhn,   Raghu N. Kacker,   Yu  Lei,   Dimitris  Simos
 
       
            
    
    
        Testing is the most commonly used approach for software assurance, yet it remains as much judgement and art as science. Structural coverage adds some rigor to the process by establishing formally defined criteria for some notion of test completeness, but