目录 一、项目概述 应用技术 接口实现: 数据库定义: 数据库建表: 博客表数据库相关操作: 添加项⽬公共模块 加密MD5 页面展示:http://121.41.168.121:8080/blog_login.html 项目源码:h
目录
页面展示:http://121.41.168.121:8080/blog_login.html
项目源码:https://gitee.com/li-dot/blogs
--建表sqlcreate database if not exists `java_blog_spring` charset utf8mb4;--⽤户表drop table if exists `java_blog_spring`.`user`;CREATE TABLE `java_blog_spring`.`user` ( `id` INT NOT NULL AUTO_INCREMENT, `user_name` VARCHAR(128) NOT NULL, `passWord` VARCHAR(128) NOT NULL, `GitHub_url` VARCHAR(128) NULL, `delete_flag` TINYINT(4) NULL DEFAULT 0, `create_time` TIMESTAMP NULL DEFAULT current_timestamp(), PRIMARY KEY (`id`), UNIQUE INDEX `user_name_UNIQUE` (`user_name` ASC))ENGINE = InnoDB DEFAULT CHARACTER SET = utf8mb4 COMMENT = '⽤户表';--博客表drop table if exists `java_blog_spring`.`blog`;CREATE TABLE `java_blog_spring`.`blog` ( `id` INT NOT NULL AUTO_INCREMENT, `title` VARCHAR(200) NULL, `content` TEXT NULL, `user_id` INT(11) NULL, `delete_flag` TINYINT(4) NULL DEFAULT 0, `create_time` TIMESTAMP NULL DEFAULT current_timestamp(), PRIMARY KEY (`id`))ENGINE = InnoDB DEFAULT CHARSET = utf8mb4 COMMENT = '博客表';--新增⽤户信息insert into `java_blog_spring`.`user` (`user_name`, `password`,`github_url`)values("zhangsan","123456","https://gitee.com");insert into `java_blog_spring`.`user` (`user_name`, `password`,`github_url`)values("lisi","123456","Https://gitee.com");insert into `java_blog_spring`.`blog` (`title`,`content`,`user_id`) values("第⼀篇博客","111我是博客正⽂我是博客正⽂我是博客正⽂",1);insert into `java_blog_spring`.`blog` (`title`,`content`,`user_id`) values("第⼆篇博客","222我是博客正⽂我是博客正⽂我是博客正⽂",2);
......
用户名:zhangsan/lisi
密码:123456
博客登录界面:
博客列表页:
博客详情页:
写博客页:
项目运行:idea2022.2.3、Maven、jdk1.8
浏览器:ChORMe、FireFox
网络:127.0.0.1:8080
测试技术: 主要采用自动化测试以及手工测试
测试人员: 李点点
PersonalBlog博客园
2023年6月--2023年7月
项目上线风险:无风险
登录页面:
PersonalBlog博客园登录页面 - 飞书云文档 (feishu.cn)
博客详情页面:
PersonalBlog博客园博客详情页面 - 飞书云文档 (feishu.cn)
登录页面:
博客页面:
编辑博客页面:
主页页面:
package BlogTest;import org.junit.jupiter.api.*;import org.junit.jupiter.params.ParameterizedTest;import org.junit.jupiter.params.provider.CsvFileSource;import org.junit.jupiter.params.provider.CsvSource;import org.junit.jupiter.params.provider.ValueSource;import org.openqa.selenium.By;import org.openqa.selenium.JavascriptExecutor;import org.openqa.selenium.WebDriver;import org.openqa.selenium.remote.RemoteWebDriverBuilder;import java.util.concurrent.TimeUnit;import static java.lang.Thread.sleep;@TestMethodOrder(MethodOrderer.OrderAnnotation.class)public class BlogCases extends InitAndEnd{ @Order(1) @ParameterizedTest //参数化 @CsvSource("zhangsan,123456") void Login(String userName,String password) throws InterruptedException { System.out.println(userName); System.out.println(password); //打开登陆页面 webDriver.get("http://121.41.168.121:8080/blog_login.html"); //输入用户名 webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS); webDriver.findElement(By.cssSelector("#userName")).sendKeys(userName); webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS); //输入密码 webDriver.findElement(By.cssSelector("#password")).sendKeys(password); webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS); //点击提交 webDriver.findElement(By.cssSelector("#submit")).click(); webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS); sleep(2000); //校验当前登录的用户是不是zhangsan,如果是则测试通过,否则测试不通过 String user_name = webDriver.findElement(By.cssSelector("h3")).getText(); webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS); Assertions.assertEquals(userName,user_name); } @Order(2)@Test void BlogList(){ webDriver.get("http://121.41.168.121:8080/blog_list.html"); webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS); int blog_num = webDriver.findElements(By.cssSelector(".title")).size(); Assertions.assertNotEquals(0,blog_num); String page_title = webDriver.getTitle(); Assertions.assertEquals(page_title,"博客列表页");}@Order(3)@Testvoid BlogDetail(){ //打开列表页 webDriver.get("http://121.41.168.121:8080/blog_list.html"); webDriver.manage().timeouts().implicitlyWait(3,TimeUnit.SECONDS); //找到查看全文按钮 webDriver.findElement(By.xpath("/html/body/div[2]/div[2]/div[1]/a")).click(); webDriver.manage().timeouts().implicitlyWait(3,TimeUnit.SECONDS); //获取博客标题 String blog_title = webDriver.findElement(By.cssSelector("body > div.container > div.right > div:nth-child(1) > div.title")).getText(); //如果博客正文不为空,测试通过 //否则测试不通过Assertions.assertNotNull(blog_title);}@Order(4)@Test void EditBlog() throws InterruptedException { // 找到写博客按钮,点击 webDriver.findElement(By.cssSelector("body > div.nav > a:nth-child(5)")).click(); webDriver.manage().timeouts().implicitlyWait(3,TimeUnit.SECONDS); // 执行js(选中标题输入框,输入字符串) ((JavascriptExecutor)webDriver).executeScript("document.querySelector(\"#title\").value =\"自动化测试\""); webDriver.manage().timeouts().implicitlyWait(3,TimeUnit.SECONDS); webDriver.findElement(By.cssSelector("#submit")).click(); webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS); // 校验页面跳转到列表页 sleep(3000); String cur_url = webDriver.getCurrentUrl(); // 校验第一条博客标题是不是刚刚发布的博客标题 String first_blog_title = webDriver.findElement(By.cssSelector("body > div.container > div.right > div:nth-child(6) > div.title")).getText(); webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS); Assertions.assertEquals("自动化测试",first_blog_title);} @Order(5) @Test void DeleteBlog(){ // 找到查看全文按钮并且点击 webDriver.manage().timeouts().implicitlyWait(3,TimeUnit.SECONDS); webDriver.findElement(By.xpath("/html/body/div[2]/div[2]/div[1]/a")).click(); webDriver.manage().timeouts().implicitlyWait(3,TimeUnit.SECONDS); // 找到删除按钮,点击 webDriver.findElement(By.cssSelector("body > div.container > div.right > div > div.operating > button:nth-child(2)")).click(); // 校验当前页面是否跳转到博客列表页面 webDriver.manage().timeouts().implicitlyWait(3,TimeUnit.SECONDS); String cur_url = webDriver.getCurrentUrl(); Assertions.assertEquals("http://121.41.168.121:8080/blog_list.html",cur_url); // 获取博客发布是时间 String blog_release_time = webDriver.findElement(By.xpath("/html/body/div[2]/div[2]/div/div[2]")).getText(); // 如果博客发布时间 包括2023-06-02测试 不通过 if(blog_release_time.contains("2023-08-04 15:49:49")){ System.out.println("博客发布时间:" + blog_release_time); System.out.println("测试不通过"); }else{ System.out.println("测试通过"); } } @Order(6) @Test void LogOut() throws InterruptedException { webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS); // 找到退出按钮,点击 webDriver.findElement(By.cssSelector("body > div.nav > a:nth-child(6)")).click(); webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS); // 校验页面是否有登录文案 String login_text= webDriver.findElement(By.cssSelector("body > div.container-login > div > h3")).getText(); // 如果有登录文案,退出成功(测试用例通过) // 否则,退出失败(测试不通过) sleep(3000); if(login_text.equals("登录")){ System.out.println("测试通过"); }else{ System.out.println("测试不通过"); } }}
来源地址:https://blog.csdn.net/qq_53332052/article/details/132040716
--结束END--
本文标题: Java个人博客系统--基于Springboot的设计与实现+测试
本文链接: https://www.lsjlt.com/news/394171.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-04-03
2024-04-03
2024-04-01
2024-01-21
2024-01-21
2024-01-21
2024-01-21
2023-12-23
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0