🚧 Symphony(引起 || 处理)Bug 日志 & PR 日志

本贴最后更新于 2689 天前,其中的信息可能已经时移俗易

由于几乎每次贡献代码,都能引起点儿 bug 出来,让我深感惭愧,故觉有必要做一下记录,避免日后重复掉坑。给 D 大添麻烦真是太不好意思了 😭
顺便记录下自己处理的 bug(两种应该都不会很多,故而 Merge 了)

🐛 查看他人主页时标签页多出匿帖
错误原因:编辑此处代码时为了解逻辑,造成标签错误闭合
此处代码定义了四个标签页,分别是帖子、回复、匿帖、匿回。代码中嵌入了显示个数的标签。少写一个,此处显示就少一个(神奇的 FreeMarker,恕我并不了解)。写错的 if 标签,是用来判断是否在查看自己的主页,只有在自己的主页下才能查看匿帖和匿回。

🐛 编辑更新帖子报 500 错误
错误原因:在添加同步开关时,针对新增文章导向的页面 post.ftl 添加了新的字段,但没有在编辑文章处对新加的字段进行赋值
此外,判断值的时候,由于 CV 代码,对值进行了错误的判断,真是蠢哭……
在做此功能时,明明搜过 post.ftl,即知道不止一个 controller 导向了 post.ftl,却没有在相应的方法上加上需要的值,导致该 controller 导向这个页面时,引用了空对象导致异常。至于 CV 代码,实在是容易引发错误啊,
日后就算 CV,只要不是同一个东西,就手敲改写

🐛 同步文章失败
错误原因:蠢。。。瞎。。。
明明不到两行的位置下面就有自己打算添加的代码,没看到,添加重了不说,还特么添加错了 orz
太毛糙,急于提交代码,没有改后进行基本的测试。
缺少艺术家那种再小的细节也要认真处理的匠心、耐心……

🐛
错误原因:pegdown 对于纯 html 解析的不够完善,会进入死循环,可参考:PegdownIssue
这个问题一开始我跑偏了,试图从 pegdown 入手解决(心真大。。。),然而纠结了两三天的代码,并没有什么很好的解决办法(实际上,由于 eclipse 对于 maven 项目源码查看的问题,我跟踪代码困难重重,基本靠猜……),最终反过来还是在 sym 上入手,然而问题来了,虽然连蒙带猜的发现,对于纯 html,如果外面包裹上一层 < p > 标签,就可以解决,然而对于非纯 html 的 MD 语法就不行了(然而我由于太激动以为解决了就 PR 了,给自己造成了代码不同步的麻烦。。。说多了都是泪。 下次 PR 前一定要自己测清楚,之前的用例必须通过再说,一旦 PR 了,要改的话最好先合并了再改)

💄 升级 emoji 表情
TAPR(Thinking After PR):这次改动主要在图片文件上,原 emojify 是基于 gemoji 的,故而支持 alias 解析,而 twemoji 并没有 alias 一说,表情多达两千,看解析似乎是通过 unicode 码,具体怎么取调用,我是没看懂,不过感觉可能是那种选图的方式,其 emoji 图片命名是通过 codepoint,所以一开始的方案是,转换 alias 到 unicode,然后再转换为 codepoint,再转换为路径(sym 使用图库的方式比较偏门,不按他们的套路来,等同于只用了图片素材)。由此纠结了很久,诸如如何处理转换不了的,有没与可能通过 codepoint 转换为 alias 的,多余的图片是否保留等,一一搞定,到了最后,处理弹出快捷表情列表的时候,发现之前的方法统统不行了。。。强行做也行,无非就是再加一个 ajax,去后台获取 alias,然而为了这么个功能,在前端加了两个 ajax 请求,刚在看 web 性能的我觉得有点蛋疼,于是放弃了,同时回滚了两天的修修补补,在五点快下班的时候,用了大概三个小时,进行了图片文件改名,也是之前讨论的第二方案。一开始就感觉改名对代码改动最小,是比较靠谱的一个方案,但是 codepoint 不知到如何转换为 alias,后来做的时候已经通过 alias 生成了 codepoint,现在只要对应一下,写个脚本改就行了(脚本写的很丑陋就不放了,多谢 sublime 列编辑……)
说这么多,总结一下就两点: 对原逻辑改动最小的总是最优办法;重点是如何达到目的,而不是考虑解决办法看起来是否炫酷优雅。。

  • B3log

    B3log 是一个开源组织,名字来源于“Bulletin Board Blog”缩写,目标是将独立博客与论坛结合,形成一种新的网络社区体验,详细请看 B3log 构思。目前 B3log 已经开源了多款产品:SymSoloVditor思源笔记

    1083 引用 • 3461 回帖 • 285 关注
  • Sym

    Sym 是一款用 Java 实现的现代化社区(论坛/BBS/社交网络/博客)系统平台。

    下一代的社区系统,为未来而构建

    523 引用 • 4581 回帖 • 690 关注
  • 开源

    Open Source, Open Mind, Open Sight, Open Future!

    396 引用 • 3416 回帖
  • Bug

    Bug 本意是指臭虫、缺陷、损坏、犯贫、窃听器、小虫等。现在人们把在程序中一些缺陷或问题统称为 bug(漏洞)。

    77 引用 • 1741 回帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • 千万不要有愧疚感。你能一起帮忙维护这个开源项目已经很好了,我们这个不是火箭上天的工程,所以上线后再测试也是可以有的。

    说起细心、耐心来,确实是个习惯,但不一定这样做就是好的或者对的。我们都知道看待事情应该分多个角度,非要衡量对错的话我想唯一标准就是看“大部分人”是否都能接受罢了。讲道理就事论事,这几个 bugs 其实也增加我们之间的沟通,并且也有其他人发现了 bug 并且报告给了我们,对于我个人来说倍感欣慰啊。说大了,这才是一个生态系统的价值,我们的目标不是产出一个 Sym 程序,而是将对这个程序、对我们在做的事情感兴趣的人连接起来,这个代谢过程才是真正的价值。

    总之,还要谢谢你的。天冷了,多喝开水~

    1 回复
  • 相比愧疚感,更多的还是烦恼自己水平问题
    希望能在不断贡献代码中,让自己成为代码的艺术家 💰

ZephyrJung
一切有为法,如梦幻泡影,如露亦如电,应作如是观 北京

推荐标签 标签

  • 招聘

    哪里都缺人,哪里都不缺人。

    189 引用 • 1056 回帖
  • 微信

    腾讯公司 2011 年 1 月 21 日推出的一款手机通讯软件。用户可以通过摇一摇、搜索号码、扫描二维码等添加好友和关注公众平台,同时可以将自己看到的精彩内容分享到微信朋友圈。

    129 引用 • 793 回帖
  • 学习

    “梦想从学习开始,事业从实践起步” —— 习近平

    161 引用 • 473 回帖 • 1 关注
  • Typecho

    Typecho 是一款博客程序,它在 GPLv2 许可证下发行,基于 PHP 构建,可以运行在各种平台上,支持多种数据库(MySQL、PostgreSQL、SQLite)。

    12 引用 • 60 回帖 • 465 关注
  • 支付宝

    支付宝是全球领先的独立第三方支付平台,致力于为广大用户提供安全快速的电子支付/网上支付/安全支付/手机支付体验,及转账收款/水电煤缴费/信用卡还款/AA 收款等生活服务应用。

    29 引用 • 347 回帖
  • Jenkins

    Jenkins 是一套开源的持续集成工具。它提供了非常丰富的插件,让构建、部署、自动化集成项目变得简单易用。

    51 引用 • 37 回帖
  • CodeMirror
    1 引用 • 2 回帖 • 120 关注
  • JWT

    JWT(JSON Web Token)是一种用于双方之间传递信息的简洁的、安全的表述性声明规范。JWT 作为一个开放的标准(RFC 7519),定义了一种简洁的,自包含的方法用于通信双方之间以 JSON 的形式安全的传递信息。

    20 引用 • 15 回帖 • 20 关注
  • gRpc
    10 引用 • 8 回帖 • 55 关注
  • frp

    frp 是一个可用于内网穿透的高性能的反向代理应用,支持 TCP、UDP、 HTTP 和 HTTPS 协议。

    15 引用 • 7 回帖 • 10 关注
  • Tomcat

    Tomcat 最早是由 Sun Microsystems 开发的一个 Servlet 容器,在 1999 年被捐献给 ASF(Apache Software Foundation),隶属于 Jakarta 项目,现在已经独立为一个顶级项目。Tomcat 主要实现了 JavaEE 中的 Servlet、JSP 规范,同时也提供 HTTP 服务,是市场上非常流行的 Java Web 容器。

    162 引用 • 529 回帖 • 3 关注
  • Telegram

    Telegram 是一个非盈利性、基于云端的即时消息服务。它提供了支持各大操作系统平台的开源的客户端,也提供了很多强大的 APIs 给开发者创建自己的客户端和机器人。

    5 引用 • 35 回帖 • 1 关注
  • 30Seconds

    📙 前端知识精选集,包含 HTML、CSS、JavaScript、React、Node、安全等方面,每天仅需 30 秒。

    • 精选常见面试题,帮助您准备下一次面试
    • 精选常见交互,帮助您拥有简洁酷炫的站点
    • 精选有用的 React 片段,帮助你获取最佳实践
    • 精选常见代码集,帮助您提高打码效率
    • 整理前端界的最新资讯,邀您一同探索新世界
    488 引用 • 383 回帖 • 5 关注
  • Hexo

    Hexo 是一款快速、简洁且高效的博客框架,使用 Node.js 编写。

    21 引用 • 140 回帖 • 28 关注
  • Kafka

    Kafka 是一种高吞吐量的分布式发布订阅消息系统,它可以处理消费者规模的网站中的所有动作流数据。 这种动作(网页浏览,搜索和其他用户的行动)是现代系统中许多功能的基础。 这些数据通常是由于吞吐量的要求而通过处理日志和日志聚合来解决。

    35 引用 • 35 回帖
  • OpenStack

    OpenStack 是一个云操作系统,通过数据中心可控制大型的计算、存储、网络等资源池。所有的管理通过前端界面管理员就可以完成,同样也可以通过 Web 接口让最终用户部署资源。

    10 引用 • 7 关注
  • Mobi.css

    Mobi.css is a lightweight, flexible CSS framework that focus on mobile.

    1 引用 • 6 回帖 • 697 关注
  • SQLServer

    SQL Server 是由 [微软] 开发和推广的关系数据库管理系统(DBMS),它最初是由 微软、Sybase 和 Ashton-Tate 三家公司共同开发的,并于 1988 年推出了第一个 OS/2 版本。

    19 引用 • 31 回帖 • 6 关注
  • Google

    Google(Google Inc.,NASDAQ:GOOG)是一家美国上市公司(公有股份公司),于 1998 年 9 月 7 日以私有股份公司的形式创立,设计并管理一个互联网搜索引擎。Google 公司的总部称作“Googleplex”,它位于加利福尼亚山景城。Google 目前被公认为是全球规模最大的搜索引擎,它提供了简单易用的免费服务。不作恶(Don't be evil)是谷歌公司的一项非正式的公司口号。

    49 引用 • 192 回帖
  • NetBeans

    NetBeans 是一个始于 1997 年的 Xelfi 计划,本身是捷克布拉格查理大学的数学及物理学院的学生计划。此计划延伸而成立了一家公司进而发展这个商用版本的 NetBeans IDE,直到 1999 年 Sun 买下此公司。Sun 于次年(2000 年)六月将 NetBeans IDE 开源,直到现在 NetBeans 的社群依然持续增长。

    78 引用 • 102 回帖 • 643 关注
  • PHP

    PHP(Hypertext Preprocessor)是一种开源脚本语言。语法吸收了 C 语言、 Java 和 Perl 的特点,主要适用于 Web 开发领域,据说是世界上最好的编程语言。

    164 引用 • 407 回帖 • 528 关注
  • Kubernetes

    Kubernetes 是 Google 开源的一个容器编排引擎,它支持自动化部署、大规模可伸缩、应用容器化管理。

    108 引用 • 54 回帖
  • 博客

    记录并分享人生的经历。

    270 引用 • 2386 回帖
  • GitLab

    GitLab 是利用 Ruby 一个开源的版本管理系统,实现一个自托管的 Git 项目仓库,可通过 Web 界面操作公开或私有项目。

    46 引用 • 72 回帖 • 1 关注
  • Love2D

    Love2D 是一个开源的, 跨平台的 2D 游戏引擎。使用纯 Lua 脚本来进行游戏开发。目前支持的平台有 Windows, Mac OS X, Linux, Android 和 iOS。

    14 引用 • 53 回帖 • 513 关注
  • golang

    Go 语言是 Google 推出的一种全新的编程语言,可以在不损失应用程序性能的情况下降低代码的复杂性。谷歌首席软件工程师罗布派克(Rob Pike)说:我们之所以开发 Go,是因为过去 10 多年间软件开发的难度令人沮丧。Go 是谷歌 2009 发布的第二款编程语言。

    492 引用 • 1383 回帖 • 374 关注
  • Maven

    Maven 是基于项目对象模型(POM)、通过一小段描述信息来管理项目的构建、报告和文档的软件项目管理工具。

    185 引用 • 318 回帖 • 344 关注