mirror of https://github.com/halo-dev/halo
commit
68a5481e5f
42
README.md
42
README.md
|
@ -1,6 +1,6 @@
|
|||
<h1>Halo</h1>
|
||||
<h1 align="center"><a href="https://github.com/halo-dev" target="_blank">Halo</a></h1>
|
||||
|
||||
> Halo 可能是最好的 Java 博客系统。(请注意,老版本已不提供维护,当前分支为新版本,正在内测中,将于近期发布版本)
|
||||
> Halo 可能是最好的 Java 博客系统。
|
||||
|
||||
<p align="center">
|
||||
<a href="https://ryanc.cc"><img alt="Author" src="https://img.shields.io/badge/author-ruibaby-red.svg?style=flat-square"/></a>
|
||||
|
@ -12,6 +12,10 @@
|
|||
|
||||
------------------------------
|
||||
|
||||
## 新版本说明
|
||||
|
||||
**老版本已不提供维护,请不要再使用老版本进行部署了,当前分支为新版本,正在内测中,将于近期发布版本**
|
||||
|
||||
## 简介
|
||||
|
||||
**Halo** [ˈheɪloʊ],意为光环。当然,你也可以当成拼音读(哈喽)。
|
||||
|
@ -63,4 +67,36 @@
|
|||
|
||||
| 支付宝/微信/QQ |
|
||||
| :------------: |
|
||||
| <img src="https://i.loli.net/2018/12/23/5c1f68ce9b884.png" width="200"/> |
|
||||
| <img src="https://i.loli.net/2018/12/23/5c1f68ce9b884.png" width="200"/> |
|
||||
|
||||
## 预览图
|
||||
|
||||
data:image/s3,"s3://crabby-images/4d65e/4d65ee62615a29bc99ae3387ced55bb909def6ea" alt="anatole.png"
|
||||
|
||||
data:image/s3,"s3://crabby-images/0fc4a/0fc4a7a1a0a62483a20c7e203525150fb5299bbc" alt="casper.png"
|
||||
|
||||
data:image/s3,"s3://crabby-images/75958/75958aa17a453bc8222ffb5f3eeaa3e89f019dd8" alt="material.png"
|
||||
|
||||
data:image/s3,"s3://crabby-images/858ba/858ba177433f60fd05370a701f82240cb50fb342" alt="admin-install.png"
|
||||
|
||||
data:image/s3,"s3://crabby-images/7c20f/7c20f22bed97e01da081806cc7c56803cf9d7c18" alt="admin-login.png"
|
||||
|
||||
data:image/s3,"s3://crabby-images/d0eea/d0eea21ec83524b23ea40f267749a8e6e18b8f96" alt="admin-dashboard.png"
|
||||
|
||||
data:image/s3,"s3://crabby-images/93ab7/93ab72ff284003534e560fcac9f4cfbbbd8ef7fa" alt="admin-posts.png"
|
||||
|
||||
data:image/s3,"s3://crabby-images/1ba86/1ba863c7d7ac9a6e41ada9de51f7904b7bed2f06" alt="admin-write.png"
|
||||
|
||||
data:image/s3,"s3://crabby-images/9c826/9c826d9ba645457ccc497a7d57f5adc7df97fab1" alt="admin-write1.png"
|
||||
|
||||
data:image/s3,"s3://crabby-images/a514d/a514d500166ee71feffab22ec18ea0824141fbc1" alt="admin-write2.png"
|
||||
|
||||
data:image/s3,"s3://crabby-images/fb0cd/fb0cd113305f5943029a3d33857ece6bfe7d9fcf" alt="admin-attachment.png"
|
||||
|
||||
data:image/s3,"s3://crabby-images/2b3a8/2b3a82dc07cf818c844330f28a56b4138b91b626" alt="admin-themes.png"
|
||||
|
||||
data:image/s3,"s3://crabby-images/8f6d9/8f6d9b79b032aedff55c30e8619cd6484da0bd85" alt="admin-theme-settings.png"
|
||||
|
||||
data:image/s3,"s3://crabby-images/c9707/c97070cd161b272ff1236d74ff70d0bd72ad7fd6" alt="admin-profile.png"
|
||||
|
||||
data:image/s3,"s3://crabby-images/4332a/4332aa8dc255a5193813e09dfb32039ea11c3273" alt="admin-options.png"
|
|
@ -36,9 +36,9 @@ public class ContentSheetController {
|
|||
*
|
||||
* @return template path: themes/{theme}/gallery.ftl
|
||||
*/
|
||||
@GetMapping(value = "/gallery")
|
||||
public String gallery() {
|
||||
return themeService.render("gallery");
|
||||
@GetMapping(value = "/photos")
|
||||
public String photos() {
|
||||
return themeService.render("photos");
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
|
@ -23,17 +23,17 @@
|
|||
</ul>
|
||||
</header>
|
||||
<section id="thumbnails">
|
||||
<@galleryTag method="list">
|
||||
<#if galleries?size gt 0>
|
||||
<#list galleries as gallery>
|
||||
<@photoTag method="list">
|
||||
<#if photos?size gt 0>
|
||||
<#list photos as photo>
|
||||
<article>
|
||||
<a class="thumbnail" href="${gallery.url}" data-position="left center"><img src="${gallery.thumbnail}" alt="${gallery.description}" /></a>
|
||||
<h2>${gallery.name}</h2>
|
||||
<p>${gallery.takeTime!}</p>
|
||||
<a class="thumbnail" href="${photo.url}" data-position="left center"><img src="${photo.thumbnail}" alt="${photo.description}" /></a>
|
||||
<h2>${photo.name}</h2>
|
||||
<p>${photo.takeTime!}</p>
|
||||
</article>
|
||||
</#list>
|
||||
</#if>
|
||||
</@galleryTag>
|
||||
</@photoTag>
|
||||
</section>
|
||||
<footer id="footer">
|
||||
<ul class="copyright">
|
|
@ -1,33 +0,0 @@
|
|||
package run.halo.app.event;
|
||||
|
||||
import lombok.extern.slf4j.Slf4j;
|
||||
import org.junit.Test;
|
||||
import org.springframework.context.ApplicationListener;
|
||||
import run.halo.app.event.logger.LogEvent;
|
||||
import run.halo.app.event.logger.LogEventListener;
|
||||
import run.halo.app.utils.ReflectionUtils;
|
||||
|
||||
import java.lang.reflect.ParameterizedType;
|
||||
import java.lang.reflect.Type;
|
||||
import java.util.Objects;
|
||||
|
||||
import static org.hamcrest.Matchers.equalTo;
|
||||
import static org.junit.Assert.*;
|
||||
|
||||
/**
|
||||
* Log event listener test.
|
||||
*
|
||||
* @author johnniang
|
||||
* @date 19-4-21
|
||||
*/
|
||||
@Slf4j
|
||||
public class LogEventListenerTest {
|
||||
|
||||
@Test
|
||||
public void getGenericTypeTest() {
|
||||
ParameterizedType parameterizedType = ReflectionUtils.getParameterizedType(ApplicationListener.class, LogEventListener.class);
|
||||
Type[] actualTypeArguments = Objects.requireNonNull(parameterizedType).getActualTypeArguments();
|
||||
Type actualTypeArgument = actualTypeArguments[0];
|
||||
assertThat(actualTypeArgument.getTypeName(), equalTo(LogEvent.class.getTypeName()));
|
||||
}
|
||||
}
|
|
@ -1,15 +1,19 @@
|
|||
package run.halo.app.service.impl;
|
||||
|
||||
import run.halo.app.model.entity.Option;
|
||||
import run.halo.app.model.properties.QnYunProperties;
|
||||
import run.halo.app.repository.OptionRepository;
|
||||
import com.qiniu.common.Zone;
|
||||
import org.junit.Test;
|
||||
import org.junit.runner.RunWith;
|
||||
import org.mockito.InjectMocks;
|
||||
import org.mockito.Mock;
|
||||
import org.mockito.junit.MockitoJUnitRunner;
|
||||
import run.halo.app.cache.StringCacheStore;
|
||||
import run.halo.app.model.entity.Option;
|
||||
import run.halo.app.model.properties.QnYunProperties;
|
||||
import run.halo.app.repository.OptionRepository;
|
||||
import run.halo.app.service.OptionService;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
import java.util.Optional;
|
||||
|
||||
import static org.hamcrest.Matchers.equalTo;
|
||||
|
@ -30,6 +34,9 @@ public class OptionServiceImplTest {
|
|||
@Mock
|
||||
private OptionRepository optionRepository;
|
||||
|
||||
@Mock
|
||||
private StringCacheStore cacheStore;
|
||||
|
||||
@InjectMocks
|
||||
private OptionServiceImpl optionService;
|
||||
|
||||
|
@ -76,13 +83,16 @@ public class OptionServiceImplTest {
|
|||
QnYunProperties zoneProperty = QnYunProperties.ZONE;
|
||||
|
||||
// Given
|
||||
given(optionRepository.findByKey(zoneProperty.getValue())).willReturn(Optional.ofNullable(option));
|
||||
// given(optionRepository.findByKey(zoneProperty.getValue())).willReturn(Optional.ofNullable(option));
|
||||
Map<String, Object> optionMap = new HashMap<>(1);
|
||||
optionMap.put(zoneProperty.getValue(), Optional.ofNullable(option).map(Option::getValue).orElse(null));
|
||||
given(cacheStore.getAny(OptionService.OPTIONS_KEY, Map.class)).willReturn(Optional.of(optionMap));
|
||||
|
||||
// When
|
||||
Zone zone = optionService.getQnYunZone();
|
||||
|
||||
// Then
|
||||
then(optionRepository).should().findByKey(zoneProperty.getValue());
|
||||
then(cacheStore).should().getAny(OptionService.OPTIONS_KEY, Map.class);
|
||||
|
||||
assertNotNull(zone);
|
||||
assertThat(zone.getRegion(), equalTo(actualZone.getRegion()));
|
||||
|
|
Loading…
Reference in New Issue