Skip to content

bytemanproject/byteman

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

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.