mirror of
https://github.com/ceph/ceph
synced 2025-01-26 13:06:29 +00:00
eb6995436f
Ceph has lots of submodules that needs to be cloned before building binaries from the repository. Seeing the progress when these submodules are being cloned is useful, especially when developers/users have a network issue or a slow network. Signed-off-by: Rishabh Dave <ridave@redhat.com>
101 lines
2.6 KiB
ReStructuredText
101 lines
2.6 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 --progress
|
|
|
|
#. 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.
|
|
|
|
|
|
|
|
|