mirror of
https://github.com/ceph/ceph
synced 2024-12-19 01:46:00 +00:00
a1f42101cf
* use `shell` lexer, otherwise the Python one is used, and the rendered result does not look right * be consistent when indenting -- either use tab or spaces, otherwise the indent in code block would be wrong. * double quote the variables in text Signed-off-by: Kefu Chai <kchai@redhat.com>
101 lines
2.5 KiB
ReStructuredText
101 lines
2.5 KiB
ReStructuredText
|
|
Corpus structure
|
|
================
|
|
|
|
ceph.git/ceph-object-corpus is a submodule.::
|
|
|
|
bin/ # misc scripts
|
|
archive/$version/objects/$type/$hash # a sample of encoded objects from a specific version
|
|
|
|
You can also mark known or deliberate incompatibilities between versions with::
|
|
|
|
archive/$version/forward_incompat/$type
|
|
|
|
The presence of a file indicates that new versions of code cannot
|
|
decode old objects across that ``$version`` (this is normally the case).
|
|
|
|
|
|
How to generate an object corpus
|
|
--------------------------------
|
|
|
|
.. highlight:: shell
|
|
|
|
We can generate an object corpus for a particular version of ceph using the
|
|
script of ``script/gen-corpus.sh``, or by following the instructions below:
|
|
|
|
#. Checkout a clean repo (best not to do this where you normally work)::
|
|
|
|
git clone ceph.git
|
|
cd ceph
|
|
git submodule update --init --recursive
|
|
|
|
#. Build with flag to dump objects to ``/tmp/foo``::
|
|
|
|
rm -rf /tmp/foo ; mkdir /tmp/foo
|
|
do_cmake.sh -DCMAKE_CXX_FLAGS="-DENCODE_DUMP_PATH=/tmp/foo"
|
|
cd build
|
|
make
|
|
|
|
#. Start via vstart::
|
|
|
|
cd build
|
|
MON=3 MGR=2 OSD=3 MDS=3 RGW=1 ../src/vstart.sh -n -x
|
|
|
|
#. Use as much functionality of the cluster as you can, to exercise as many object encoder methods as possible::
|
|
|
|
bin/ceph osd pool create mypool
|
|
bin/rados -p mypool bench 10 write -b 123
|
|
bin/ceph osd out 0
|
|
bin/ceph osd in 0
|
|
bin/init-ceph restart osd.1
|
|
for f in ../qa/workunits/cls/*.sh ; do PATH="bin:$PATH" $f ; done
|
|
PATH="bin:$PATH" ../qa/workunits/rados/test.sh
|
|
bin/ceph_test_librbd
|
|
bin/ceph_test_libcephfs
|
|
bin/init-ceph restart mds.a
|
|
../qa/workunits/rgw/run-s3tests.sh
|
|
|
|
#. Stop::
|
|
|
|
../src/stop.sh
|
|
|
|
#. Import the corpus (this will take a few minutes)::
|
|
|
|
../src/test/encoding/import.sh /tmp/foo `bin/ceph-dencoder version` ../ceph-object-corpus/archive
|
|
../src/test/encoding/import-generated.sh ../ceph-object-corpus/archive
|
|
|
|
#. Prune it! There will be a bazillion copies of various objects, and we only want a representative sample.::
|
|
|
|
pushd ../ceph-object-corpus
|
|
bin/prune-archive.sh
|
|
popd
|
|
|
|
#. Verify the tests pass::
|
|
|
|
ctest -R readable.sh
|
|
|
|
#. Commit it to the corpus repo and push::
|
|
|
|
pushd ../ceph-object-corpus
|
|
git checkout -b wip-new
|
|
git add archive/`../build/bin/ceph-dencoder version`
|
|
git commit -m `../build/bin/ceph-dencoder version`
|
|
git remote add cc git@github.com:ceph/ceph-object-corpus.git
|
|
git push cc wip-new
|
|
popd
|
|
|
|
#. Go test it out::
|
|
|
|
cd my/regular/tree
|
|
cd ceph-object-corpus
|
|
git fetch origin
|
|
git checkout wip-new
|
|
cd ../build
|
|
ctest -R readable.sh
|
|
|
|
#. If everything looks good, update the submodule master branch, and commit the submodule in ceph.git.
|
|
|
|
|
|
|
|
|