-
Notifications
You must be signed in to change notification settings - Fork 151
Byteman Project main repo
bytemanproject/byteman
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation
Byteman README -------------- Byteman supports injection of side effects into Java programs for the purpose of tracing and testing application behaviour. Installation ------------ When you unzip the downloaded release it will explode to a single target install directory containing everything you need to use byteman. You should set environment variable BYTEMAN_HOME so that it points to this target install directory. The install directory for the binary release contains the following subdirectories bin -- contains Unix scripts to simplify: using Byteman (bmjava.sh); typechecking Byteman rule scripts (bytemancheck.sh); communicating with the Byteman agent listener (bmsubmit.sh); and installing the agent into a running JVM (bminstall.sh). You will need to change the permissions of these files in order to execute them directly from the command line. docs -- contains the Byteman Programmer's guide and license information for Byteman plus the third-party software it uses lib -- contains the Byteman agent and rule engine (byteman.jar); the subset of this code needed to compile/run the submit client (byteman-submit.jar); the subset of this code needed to compile/run the install client (byteman-install.jar). sample/scripts -- contains example rule scripts showing how to use Byteman sample/lib -- contains helper code for the sample scripts contrib -- contains software contributed by other Byteman users see the README in each contrib subdirectory for details of how to use the package The install directory for the full source release contains all the above directories plus the following extra directories sources -- contains source code jars for each of the component jars in lib, sample/lib, contrib/dtest and contrib/bmunit javadoc -- contains javadoc format documentation jars for each of the component jars in lib, sample/lib, contrib/dtest and contrib/bmunit Using Byteman ------------- Access to the Byteman project downloads, documentation, user and developer forums and source code is available from the project home page at http://www.jboss.org/byteman Please consult the Programmer's Guide for details of how Byteman operates, how to write Byteman rule scripts and how to run a Java program with the Byteman agent in place. Take a look at the sample scripts directory to see some examples of how you can use Byteman to trace application and JVM execution or to gather and present statistics detailing the operation of JVM or application code. (n.b. these examples still need extending to show how to use Byteman for fault injection based testing). Compiling Byteman ----------------- To compile source code use Maven command `mvn clean install`. Byteman will be compiled, the command generates documentation and distribution artifacts can be found at `download/target`. To speed-up compilation you can skip tests and generating the documentation with `mvn clean install -DskipITs -DskipTests -DskipDocs`. Copyright --------- See the copyright file in the docs directory for details of the open source license under which this code is released. Note that this code employs the ObjectWeb ASM package to do bytecode manipulation and the JFlex and JavaCUP tokeniser and parser generators to generate and provide runtime support for the rule parser which are also released under open source licenses.