@ -9,6 +9,7 @@ import static org.eclipse.jgit.internal.storage.pack.PackExt.REFTABLE;
import static org.junit.Assert.assertEquals ;
import static org.junit.Assert.assertEquals ;
import static org.junit.Assert.assertFalse ;
import static org.junit.Assert.assertFalse ;
import static org.junit.Assert.assertNotNull ;
import static org.junit.Assert.assertNotNull ;
import static org.junit.Assert.assertNull ;
import static org.junit.Assert.assertSame ;
import static org.junit.Assert.assertSame ;
import static org.junit.Assert.assertTrue ;
import static org.junit.Assert.assertTrue ;
import static org.junit.Assert.fail ;
import static org.junit.Assert.fail ;
@ -18,6 +19,7 @@ import java.util.Collections;
import java.util.concurrent.TimeUnit ;
import java.util.concurrent.TimeUnit ;
import org.eclipse.jgit.internal.storage.dfs.DfsObjDatabase.PackSource ;
import org.eclipse.jgit.internal.storage.dfs.DfsObjDatabase.PackSource ;
import org.eclipse.jgit.internal.storage.dfs.DfsRefDatabase ;
import org.eclipse.jgit.internal.storage.reftable.RefCursor ;
import org.eclipse.jgit.internal.storage.reftable.RefCursor ;
import org.eclipse.jgit.internal.storage.reftable.ReftableConfig ;
import org.eclipse.jgit.internal.storage.reftable.ReftableConfig ;
import org.eclipse.jgit.internal.storage.reftable.ReftableReader ;
import org.eclipse.jgit.internal.storage.reftable.ReftableReader ;
@ -842,6 +844,106 @@ public class DfsGarbageCollectorTest {
}
}
}
}
@Test
public void reftableWithoutTombstoneResurrected ( ) throws Exception {
RevCommit commit0 = commit ( ) . message ( "0" ) . create ( ) ;
String NEXT = "refs/heads/next" ;
DfsRefDatabase refdb = ( DfsRefDatabase ) repo . getRefDatabase ( ) ;
git . update ( NEXT , commit0 ) ;
Ref next = refdb . exactRef ( NEXT ) ;
assertNotNull ( next ) ;
assertEquals ( commit0 , next . getObjectId ( ) ) ;
git . delete ( NEXT ) ;
refdb . clearCache ( ) ;
assertNull ( refdb . exactRef ( NEXT ) ) ;
DfsGarbageCollector gc = new DfsGarbageCollector ( repo ) ;
gc . setReftableConfig ( new ReftableConfig ( ) ) ;
gc . setIncludeDeletes ( false ) ;
gc . setConvertToReftable ( false ) ;
run ( gc ) ;
assertEquals ( 1 , odb . getReftables ( ) . length ) ;
try ( DfsReader ctx = odb . newReader ( ) ;
ReftableReader rr = odb . getReftables ( ) [ 0 ] . open ( ctx ) ) {
rr . setIncludeDeletes ( true ) ;
assertEquals ( 1 , rr . minUpdateIndex ( ) ) ;
assertEquals ( 2 , rr . maxUpdateIndex ( ) ) ;
assertNull ( rr . exactRef ( NEXT ) ) ;
}
RevCommit commit1 = commit ( ) . message ( "1" ) . create ( ) ;
DfsPackDescription t1 = odb . newPack ( INSERT ) ;
Ref newNext = new ObjectIdRef . PeeledNonTag ( Ref . Storage . LOOSE , NEXT ,
commit1 ) ;
try ( DfsOutputStream out = odb . writeFile ( t1 , REFTABLE ) ) {
ReftableWriter w = new ReftableWriter ( ) ;
w . setMinUpdateIndex ( 1 ) ;
w . setMaxUpdateIndex ( 1 ) ;
w . begin ( out ) ;
w . writeRef ( newNext , 1 ) ;
w . finish ( ) ;
t1 . addFileExt ( REFTABLE ) ;
t1 . setReftableStats ( w . getStats ( ) ) ;
}
odb . commitPack ( Collections . singleton ( t1 ) , null ) ;
assertEquals ( 2 , odb . getReftables ( ) . length ) ;
refdb . clearCache ( ) ;
newNext = refdb . exactRef ( NEXT ) ;
assertNotNull ( newNext ) ;
assertEquals ( commit1 , newNext . getObjectId ( ) ) ;
}
@Test
public void reftableWithTombstoneNotResurrected ( ) throws Exception {
RevCommit commit0 = commit ( ) . message ( "0" ) . create ( ) ;
String NEXT = "refs/heads/next" ;
DfsRefDatabase refdb = ( DfsRefDatabase ) repo . getRefDatabase ( ) ;
git . update ( NEXT , commit0 ) ;
Ref next = refdb . exactRef ( NEXT ) ;
assertNotNull ( next ) ;
assertEquals ( commit0 , next . getObjectId ( ) ) ;
git . delete ( NEXT ) ;
refdb . clearCache ( ) ;
assertNull ( refdb . exactRef ( NEXT ) ) ;
DfsGarbageCollector gc = new DfsGarbageCollector ( repo ) ;
gc . setReftableConfig ( new ReftableConfig ( ) ) ;
gc . setIncludeDeletes ( true ) ;
gc . setConvertToReftable ( false ) ;
run ( gc ) ;
assertEquals ( 1 , odb . getReftables ( ) . length ) ;
try ( DfsReader ctx = odb . newReader ( ) ;
ReftableReader rr = odb . getReftables ( ) [ 0 ] . open ( ctx ) ) {
rr . setIncludeDeletes ( true ) ;
assertEquals ( 1 , rr . minUpdateIndex ( ) ) ;
assertEquals ( 2 , rr . maxUpdateIndex ( ) ) ;
next = rr . exactRef ( NEXT ) ;
assertNotNull ( next ) ;
assertNull ( next . getObjectId ( ) ) ;
}
RevCommit commit1 = commit ( ) . message ( "1" ) . create ( ) ;
DfsPackDescription t1 = odb . newPack ( INSERT ) ;
Ref newNext = new ObjectIdRef . PeeledNonTag ( Ref . Storage . LOOSE , NEXT ,
commit1 ) ;
try ( DfsOutputStream out = odb . writeFile ( t1 , REFTABLE ) ) {
ReftableWriter w = new ReftableWriter ( ) ;
w . setMinUpdateIndex ( 1 ) ;
w . setMaxUpdateIndex ( 1 ) ;
w . begin ( out ) ;
w . writeRef ( newNext , 1 ) ;
w . finish ( ) ;
t1 . addFileExt ( REFTABLE ) ;
t1 . setReftableStats ( w . getStats ( ) ) ;
}
odb . commitPack ( Collections . singleton ( t1 ) , null ) ;
assertEquals ( 2 , odb . getReftables ( ) . length ) ;
refdb . clearCache ( ) ;
assertNull ( refdb . exactRef ( NEXT ) ) ;
}
private TestRepository < InMemoryRepository > . CommitBuilder commit ( ) {
private TestRepository < InMemoryRepository > . CommitBuilder commit ( ) {
return git . commit ( ) ;
return git . commit ( ) ;
}
}