Fuzzing is a software testing technique used to discover coding errors and security loopholes in software, operating systems or networks by inputting massive amounts of
random data, called
fuzz, to the system in an attempt to make it
crash. A fuzzer is written to do the fuzzing.