【工具类】: 判断字符串是否为空。
package cn.simplelife.util;
/**
* @ClassName StringUtil
* @Description
* @Author simplelife
* @Date 2022/8/30 10:55
* @Version 1.0
*/
public class StringUtil {
//字符串判断是否为空
public static boolean hasLength(String val) {
return val != null && "".equals(val.trim());
}
}







package cn.simplelife.app;
import cn.simplelife.util.StringUtil;
/**
* @ClassName App
* @Description
* @Author simplelife
* @Date 2022/8/30 10:59
* @Version 1.0
*/
public class App {
public static void main(String[] args) {
String username = "";
System.out.println(StringUtil.hasLength(username));
}
}
在软件生命周期中,测试是一个重要的环节,它从编码开始,甚至可能早于编码就已经进入了软件生命周期了。优秀的软件不是开发出来的,而是测试出来的。 一个软件的开发是否完成,不是开发人员说了算的,而是测试人员说了算的,只有经过严密的测试,才能上线。
1、【黑盒测试】: 黑盒测试也称为功能测试,是通过测试来检测每一个功能是否能正常使用,把程序看作一个不能打开的黑盒子,在完全不考虑内部结构和内部特性的情况下,在程序的接口上进行测试,检查程序功能是否按照需求规格说明书的规定正常使用。
【测试方式】: 手动测试,不需要写代码。
【作用】:
2、【白盒测试】: 由开发人员来测试。又称为结构测试,透明盒测试,罗技驱动测试或基于代码的测试。它是按照程序内部的机构测试程序,通过测试来检测茶农内部动作是否按照设计规格说明书的规定正常执行。测试者必须检查程序内部结构,从检查程序的逻辑着手,得出测试数据。
【测试方式】: 代码测试、需要写代码。
【作用】:
JUnit是由 Erich Gamma 和 Kent Beck 编写的一个回归测试框架(regression testing framework)。Junit测试是程序员测试,即所谓白盒测试,因为程序员知道被测试的软件如何(How)完成功能和完成什么样(What)的功能。Junit是一套框架,继承TestCase类,就可以用Junit进行自动测试了。
【官网】: JUnit
【版本】:
class Person{
public void work(){
System.out.println("人可以走路");
}
}
class PersonTest{
public static void main(String[] args){
Person p = new Person();
p.work();
}
}
// 问题发现:如果要测试很多个方法,就需要我们创建很多个测试类,然后创建对象,调用方法,非常麻烦,要保证每个功能的修改都能马上执行测试,目前实现太过繁琐。
Idea 插件安装:File -> Settings -> Plugins -> 搜索 junit ,默认是自带的,没有的在此处安装

package cn.simplelife.junit;
/**
* @ClassName UserDaoImpl
* @Description
* @Author simplelife
* @Date 2022/8/30 11:23
* @Version 1.0
*/
public class UserDaoImpl {
public int add(int num1, int num2) {
return num1 + num2;
}
public void delete(int index) {
System.out.println("删除索引为" + index + "的数值!");
}
}



package cn.simplelife.test;
import cn.simplelife.junit.UserDaoImpl;
import org.junit.Test;
/**
* @ClassName UserDaoTest
* @Description
* @Author simplelife
* @Date 2022/8/30 11:26
* @Version 1.0
*/
public class UserDaoTest {
private UserDaoImpl userDao = new UserDaoImpl();
@Test
public void testAdd() {
System.out.println(userDao.add(12, 11));
}
@Test
public void testDelete() {
userDao.delete(1);
}
}



在开发中,有时候存一些数据是直接在代码的变量中实现的,但如果变量的值是需要偶尔改下的,这个时候就存在了硬编码。
【举例一下】: 在用Java语言区连接数据库的时候,我们需要使用数据库的账号、密码,此时我们使用两个变量来记录:
private String username="root";
private String password="???";
如果想要使用账号密码,直接重复使用两个变量即可。但是如果后期账号密码发生变化、我们使用到的地方都需要我们去一一修改,此时的工作量就变得尤为巨大。
【解决方法】: 此时我们只需要将这些容易变化的内容写到文件中,通过读取文件的方式进行使用,在后期我们需要修改的时候,只需要修改文件中的内容即可,大大的减少了工作量。
【简介】: 该文件被称为属性文件、资源文件、配置文件,以properties作为文件后缀名。
【存数据特点】: key = value格式,多对数据使用换行分开。
【举例】:
driverClassName=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/???
username=root
password=????
【使用注意事项】:
【使用步骤】:

Properties是Map的实现类,可以继承过来map的常见操作方法(get、put…),map中的方法,我们一般都不用,Properties文件比较特殊,使用Properties类的新增的方法。
【常用API】:
【使用相对路径来加载配置文件】:
package cn.simplelife.properties;
import java.io.InputStream;
import java.util.Properties;
/**
* @ClassName LoadProperties
* @Description
* @Author simplelife
* @Date 2022/8/30 16:06
* @Version 1.0
*/
public class LoadProperties {
public static void main(String[] args) throws Exception {
// 0、获取类加载器对象
// ClassLoader classLoader = LoadProperties.class.getClassLoader();
ClassLoader contextClassLoader = Thread.currentThread().getContextClassLoader();
InputStream resourceAsStream = contextClassLoader.getResourceAsStream("user.properties");
// 1、创建properties对象
Properties properties = new Properties();
//FileInputStream fileInputStream = new FileInputStream("F:\\JavaWeb\\day01\\resources\\user.properties");
// 2、使用load方法加载配置文件
if (resourceAsStream != null) {
properties.load(resourceAsStream);
}
String username = properties.getProperty("username");
String password = properties.getProperty("password");
System.out.println("username = " + username);
System.out.println("password = " + password);
}
}
很好奇,就使用rubyonrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提
我正在尝试测试是否存在表单。我是Rails新手。我的new.html.erb_spec.rb文件的内容是:require'spec_helper'describe"messages/new.html.erb"doit"shouldrendertheform"dorender'/messages/new.html.erb'reponse.shouldhave_form_putting_to(@message)with_submit_buttonendendView本身,new.html.erb,有代码:当我运行rspec时,它失败了:1)messages/new.html.erbshou
我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-
我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t
我有一个对象has_many应呈现为xml的子对象。这不是问题。我的问题是我创建了一个Hash包含此数据,就像解析器需要它一样。但是rails自动将整个文件包含在.........我需要摆脱type="array"和我该如何处理?我没有在文档中找到任何内容。 最佳答案 我遇到了同样的问题;这是我的XML:我在用这个:entries.to_xml将散列数据转换为XML,但这会将条目的数据包装到中所以我修改了:entries.to_xml(root:"Contacts")但这仍然将转换后的XML包装在“联系人”中,将我的XML代码修改为
为了将Cucumber用于命令行脚本,我按照提供的说明安装了arubagem。它在我的Gemfile中,我可以验证是否安装了正确的版本并且我已经包含了require'aruba/cucumber'在'features/env.rb'中为了确保它能正常工作,我写了以下场景:@announceScenario:Testingcucumber/arubaGivenablankslateThentheoutputfrom"ls-la"shouldcontain"drw"假设事情应该失败。它确实失败了,但失败的原因是错误的:@announceScenario:Testingcucumber/ar
我在我的项目中添加了一个系统来重置用户密码并通过电子邮件将密码发送给他,以防他忘记密码。昨天它运行良好(当我实现它时)。当我今天尝试启动服务器时,出现以下错误。=>BootingWEBrick=>Rails3.2.1applicationstartingindevelopmentonhttp://0.0.0.0:3000=>Callwith-dtodetach=>Ctrl-CtoshutdownserverExiting/Users/vinayshenoy/.rvm/gems/ruby-1.9.3-p0/gems/actionmailer-3.2.1/lib/action_mailer
我正在编写一个包含C扩展的gem。通常当我写一个gem时,我会遵循TDD的过程,我会写一个失败的规范,然后处理代码直到它通过,等等......在“ext/mygem/mygem.c”中我的C扩展和在gemspec的“扩展”中配置的有效extconf.rb,如何运行我的规范并仍然加载我的C扩展?当我更改C代码时,我需要采取哪些步骤来重新编译代码?这可能是个愚蠢的问题,但是从我的gem的开发源代码树中输入“bundleinstall”不会构建任何native扩展。当我手动运行rubyext/mygem/extconf.rb时,我确实得到了一个Makefile(在整个项目的根目录中),然后当
我有一个围绕一些对象的包装类,我想将这些对象用作散列中的键。包装对象和解包装对象应映射到相同的键。一个简单的例子是这样的:classAattr_reader:xdefinitialize(inner)@inner=innerenddefx;@inner.x;enddef==(other)@inner.x==other.xendenda=A.new(o)#oisjustanyobjectthatallowso.xb=A.new(o)h={a=>5}ph[a]#5ph[b]#nil,shouldbe5ph[o]#nil,shouldbe5我试过==、===、eq?并散列所有无济于事。
我的瘦服务器配置了nginx,我的ROR应用程序正在它们上运行。在我发布代码更新时运行thinrestart会给我的应用程序带来一些停机时间。我试图弄清楚如何优雅地重启正在运行的Thin实例,但找不到好的解决方案。有没有人能做到这一点? 最佳答案 #Restartjustthethinserverdescribedbythatconfigsudothin-C/etc/thin/mysite.ymlrestartNginx将继续运行并代理请求。如果您将Nginx设置为使用多个上游服务器,例如server{listen80;server