You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

DefaultUploadPackFactoryTest.java 4.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. /*
  2. * Copyright (C) 2009-2010, Google Inc. and others
  3. *
  4. * This program and the accompanying materials are made available under the
  5. * terms of the Eclipse Distribution License v. 1.0 which is available at
  6. * https://www.eclipse.org/org/documents/edl-v10.php.
  7. *
  8. * SPDX-License-Identifier: BSD-3-Clause
  9. */
  10. package org.eclipse.jgit.http.test;
  11. import static org.junit.Assert.assertNotNull;
  12. import static org.junit.Assert.assertSame;
  13. import static org.junit.Assert.fail;
  14. import java.io.IOException;
  15. import javax.servlet.http.HttpServletRequest;
  16. import javax.servlet.http.HttpServletRequestWrapper;
  17. import org.eclipse.jetty.server.Request;
  18. import org.eclipse.jgit.http.server.resolver.DefaultUploadPackFactory;
  19. import org.eclipse.jgit.junit.LocalDiskRepositoryTestCase;
  20. import org.eclipse.jgit.lib.Repository;
  21. import org.eclipse.jgit.lib.StoredConfig;
  22. import org.eclipse.jgit.transport.UploadPack;
  23. import org.eclipse.jgit.transport.resolver.ServiceNotAuthorizedException;
  24. import org.eclipse.jgit.transport.resolver.ServiceNotEnabledException;
  25. import org.eclipse.jgit.transport.resolver.UploadPackFactory;
  26. import org.junit.Before;
  27. import org.junit.Test;
  28. public class DefaultUploadPackFactoryTest extends LocalDiskRepositoryTestCase {
  29. private Repository db;
  30. private UploadPackFactory<HttpServletRequest> factory;
  31. @Override
  32. @Before
  33. public void setUp() throws Exception {
  34. super.setUp();
  35. db = createBareRepository();
  36. factory = new DefaultUploadPackFactory();
  37. }
  38. @SuppressWarnings("unchecked")
  39. @Test
  40. public void testDisabledSingleton() throws ServiceNotAuthorizedException {
  41. factory = (UploadPackFactory<HttpServletRequest>) UploadPackFactory.DISABLED;
  42. try {
  43. factory.create(new R(null, "localhost"), db);
  44. fail("Created session for anonymous user: null");
  45. } catch (ServiceNotEnabledException e) {
  46. // expected not authorized
  47. }
  48. try {
  49. factory.create(new R("", "localhost"), db);
  50. fail("Created session for anonymous user: \"\"");
  51. } catch (ServiceNotEnabledException e) {
  52. // expected not authorized
  53. }
  54. try {
  55. factory.create(new R("bob", "localhost"), db);
  56. fail("Created session for user: \"bob\"");
  57. } catch (ServiceNotEnabledException e) {
  58. // expected not authorized
  59. }
  60. }
  61. @Test
  62. public void testCreate_Default() throws ServiceNotEnabledException,
  63. ServiceNotAuthorizedException {
  64. UploadPack up;
  65. up = factory.create(new R(null, "1.2.3.4"), db);
  66. assertNotNull("have UploadPack", up);
  67. assertSame(db, up.getRepository());
  68. up = factory.create(new R("bob", "1.2.3.4"), db);
  69. assertNotNull("have UploadPack", up);
  70. assertSame(db, up.getRepository());
  71. }
  72. @Test
  73. public void testCreate_Disabled() throws ServiceNotAuthorizedException,
  74. IOException {
  75. final StoredConfig cfg = db.getConfig();
  76. cfg.setBoolean("http", null, "uploadpack", false);
  77. cfg.save();
  78. try {
  79. factory.create(new R(null, "localhost"), db);
  80. fail("Created session for anonymous user: null");
  81. } catch (ServiceNotEnabledException e) {
  82. // expected not authorized
  83. }
  84. try {
  85. factory.create(new R("bob", "localhost"), db);
  86. fail("Created session for user: \"bob\"");
  87. } catch (ServiceNotEnabledException e) {
  88. // expected not authorized
  89. }
  90. }
  91. @Test
  92. public void testCreate_Enabled() throws ServiceNotEnabledException,
  93. ServiceNotAuthorizedException {
  94. db.getConfig().setBoolean("http", null, "uploadpack", true);
  95. UploadPack up;
  96. up = factory.create(new R(null, "1.2.3.4"), db);
  97. assertNotNull("have UploadPack", up);
  98. assertSame(db, up.getRepository());
  99. up = factory.create(new R("bob", "1.2.3.4"), db);
  100. assertNotNull("have UploadPack", up);
  101. assertSame(db, up.getRepository());
  102. }
  103. private static final class R extends HttpServletRequestWrapper {
  104. private final String user;
  105. private final String host;
  106. R(String user, String host) {
  107. super(new Request(null, null) /* can't pass null, sigh */);
  108. this.user = user;
  109. this.host = host;
  110. }
  111. @Override
  112. public String getRemoteHost() {
  113. return host;
  114. }
  115. @Override
  116. public String getRemoteUser() {
  117. return user;
  118. }
  119. }
  120. }